我有一个简单的设置:单击图像后,我想要播放 mp3 文件。
从我记得的大多数来源中,建议是创建一个虚拟跨度元素,可以在其中嵌入音频播放器以在单击图像时自动启动。
这是执行此类操作的函数:
<script language="javascript" type="text/javascript">
function playSound(soundfile,evt) {
document.getElementById("dummy").innerHTML = "<embed src=\""+soundfile+"\" hidden=\"true\" autostart=\"true\" loop=\"false\" />";
evt.preventDefault(); // this doesnt do anything
return false; // neither does this
}
</script>
图片的 HTML 代码:
<a href="#" onclick="playSound('aud.mp3'); return false;">
我将“虚拟”跨度放在页面的最底部。单击图像时,会播放声音,但令人难以置信的是页面会自动向下滚动到此 span 元素的位置。
我在 IE 和 Firefox 上试过这个:这个问题没有发生。仅在最新版本的 Chrome (24.0.1312.56 m) 中才会发生这种情况。我在两台电脑上试过这个。
有谁知道怎么回事?你如何摆脱这个烦人的滚动?
return false;
没有帮助(它们都没有;第二个只是通过属性滚动到顶部)#
。也没有preventDefault()
。也不会将 ahref
属性从更改#
为javascript:void(0)
。