- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我希望有人能够帮助解决我遇到的问题。下面的代码管理我正在开发的网站上的音频播放器。这个想法是,用户可以单击静音按钮来切换网站上的声音,如果用户单击特定链接离开网站,则声音应该被静音(如果尚未静音)。
因此,下面脚本的第一部分为音频播放器(音频 html5 标签)(audioPlayer) 设置一个全局变量,第二部分为用户可以单击的静音按钮设置一个全局变量。
<script type="text/javascript">
var muteAudio = document.getElementById('audioPlayer'),
ctrl = document.getElementById('audioControl');
然后,如果有人单击静音按钮,我会将静音按钮的内部 html 更新为静音或播放,具体取决于按钮所处的状态
ctrl.onclick = function () {
// Update the Button
var pause = ctrl.innerHTML === 'Mute';
ctrl.innerHTML = pause ? 'Play' : 'Mute';
然后我更新了 html 5 音频嵌入方法
// Update the Audio
var method = pause ? 'pause' : 'play';
muteAudio[method]();
// Prevent Default Action
return false;
};
脚本的第二部分为将用户带到电子商务商店的外部链接 (SHOP) 设置第三个全局变量。如果声音打开,则当用户离开时,声音应该静音。如果声音没有打开,则不应执行此 if 语句
ctrl3 = document.getElementById('muter');
if (ctrl.innerHTML.indexOf('Mute') != -1) {
console.log('not-muted');
ctrl3.onclick = function () {
$("#audioControl").click();
return false;
};
}
else {console.log('did nothing');}
</script>
问题是 if 语句似乎不起作用。如果音频被静音,则当用户退出在线商店时,不应执行静音按钮上的单击功能来静音。发生的情况是 if 语句似乎总是正确的,因为无论静音按钮是否处于播放状态(即静音按钮显示静音/内部 html),如果音乐正在播放并切换,它都会将声音切换为关闭如果音乐关闭则声音打开(似乎忽略了内部 html 文本的 if 语句检查。
您可以在这里看到它 http://goo.gl/DJMJBx
感谢您的帮助!
最佳答案
问题在于 ctrl3 的点击处理程序是有条件附加的。
您想要的是无条件附加处理程序,并在处理程序内执行测试 - 即每当单击链接时。
这是为了使用 jQuery 而重新设计的整个过程。
$(function() {
var $audio = $('#audioPlayer'),
$audioControl = $('#audioControl');
$audioControl.on('click', function (e) {
e.preventDefault();
var pause = $audioControl.html() === 'Mute';
$audioControl.html(pause ? 'Play' : 'Mute');
$audio.get(0)[pause ? 'pause' : 'play']();
});
$('#muter').on('click', function (e) {
if ($audioControl.html() === 'Mute') {
$audioControl.click();
};
});
});
关于javascript - 现场 HTML 5 音频控件无法正常工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27684354/
我刚接触一个项目,开发人员仍然通过邮件发送文件来共享代码。我们正在使用 eclipse 和 cvs。 场外的开发人员将代码发送到现场进行审核,其他开发人员从那里的邮件中一一获取文件并在 Eclipse
我完成了 session 站点设计,现在应该创建数据库。但我不确定该使用哪种方法。我正在使用 Apache、PHP 和 MySQL。我有用户,每个用户都有输入和输出邮箱,每个用户都有一个好友列表。这是
我们的开发团队刚刚将一个应用程序从本地服务器迁移到实时站点。该应用程序利用可写入的远程数据库,并利用 MSQLi 和 PDO 方法获取数据并将数据推送到数据库。 更新 connect .inc 文件以
大家好,我想使用 java 连接到我网站上的数据库。我想知道我应该在 URL 中输入什么: cnt=DriverManager.getConnection(DB_URL, DB_UID,DB_PWD)
我不确定“硬失败”是否是正确的词,但这是我面临的问题。我花了相当长的时间来重现这个尽可能最小的例子,所以它是这样的: class BaseParameterizedType fun > getSpec
我希望有人能够帮助解决我遇到的问题。下面的代码管理我正在开发的网站上的音频播放器。这个想法是,用户可以单击静音按钮来切换网站上的声音,如果用户单击特定链接离开网站,则声音应该被静音(如果尚未静音)。
我在站点中使用 libcurl 进行身份验证。我用它制作了很多功能,例如: char *CheckLoginPass(char *login, char *pass) { //use curl_e
我正在创建一个社交媒体风格的网站,并使用 Meteor 和 MongoDB 创建帖子,其中包含 {{title}} 和 {{content}}一个 Accordion 菜单,标题在菜单的标题上,内容在
我昨天为一个网站写了一个小的桌面 package 器(它实际上只是加载一个网站),作为对 Electron 的一些练习,但我注意到以下事情: 通常应该(并且确实)在每个浏览器上工作的 Javascri
我的应用程序中有 WebView 。我可以在 IDE 中看到警告。“使用 setJavaScriptEnabled 会引入 XSS 漏洞”代码 webView.getSettings().setJav
我正在做一个多步骤表单,所有内容都在最后保存。在我的模型中,我有一个 m2m 复选框字段,并且我使用 django Sessions 来获取表单数据以在最后一步中显示它。 问题是当我提交最终表单时,m
我们已经实现了 WURFL 现场 Java 应用程序(使用 maven/servlet 实现的 berryapp),我们将其用于所有 Java 应用程序,只需在所有其他应用程序中调用该应用程序即可。由
我是一名优秀的程序员,十分优秀!