实现控制网站背景音乐的播放暂停在html5中是非常容易和简单的,仅仅几行代码即可实现。
首先在网页中嵌入背景音乐,html5代码为:

  • <script src="http://wuover.qiniudn.com/jquery.js"></script>
  • <a class="mscBtn" id="audioBtn" title='最幸福的人' style="cursor:pointer;"></a>
  • <audio id="bgMusic" src="http://cctv3.qiniudn.com/zuixingfuderen.mp3" autoplay="autoplay"></audio>

通过audio的id即可控制音乐的播放(play())和暂停(pause()),同时通过改变class改变按钮的背景图片,js代码为(切记要引入jq库):

  • $(function(){
  • var music = document.getElementById("bgMusic");
  • $("#audioBtn").click(function(){
  • if(music.paused){music.play();
  • $("#audioBtn").removeClass("pause").addClass("play");
  • }else{music.pause();
  • $("#audioBtn").removeClass("play").addClass("pause");}});
  • });

css样式为:

  • .pause {background-position: 0 bottom;}
  • .mscBtn {height: 50px;
  • background: #fff url(http://cctv2.qiniudn.com/musicbtn.png) no-repeat;
  • display: block;}

demo效果就是本页面,当你打开了该页面之后一定有音乐播放,如果你按以下的按钮没反应,请点击这里刷新页面后再点击下面的图标。

 

应大伙的要求,改进了下,让网页背景音乐支持多首歌曲,播放完在随机播放下一首并且不会和上一首重复,并提供播放暂停按钮,本来这篇文章只是提供最简单的功能让大家自行扩展的,既然大家都提到了这个,我在评论里面也回了,在把最终的版本写在这篇文章后续上,主要就是js换成以下的:

  • $(function(){
  • var music = document.getElementById("bgMusic");
  • var musicArr=[//下面对应歌曲链接和歌名,自行添加用,隔开
  • {url:'http://cctv3.qiniudn.com/tbhdqx.mp3',title:"唐伯虎点秋香"},
  • {url:'http://cctv3.qiniudn.com/abzxh.mp3',title:"敖包再相会"},
  • {url:'http://cctv3.qiniudn.com/lmzda.mp3',title:"辣妹子的爱"},
  • {url:'http://cctv3.qiniudn.com/32.mp3',title:"32号嫁给你"},
  • {url:'http://cctv3.qiniudn.com/tongxinjishou.mp3',title:"痛心疾首"},
  • {url:'http://cctv3.qiniudn.com/rgangdst.mp3',title:"如果爱能感动上天"},
  • {url:'http://cctv3.qiniudn.com/cz.mp3',title:"车站"},
  • {url:'http://cctv3.qiniudn.com/hn.ogg',title:"很难"},
  • {url:'http://cctv3.qiniudn.com/aqlmysdsc.mp3',title:"爱情里没有谁对谁错"},
  • {url:'http://cctv3.qiniudn.com/dlaqdln.mp3',title:"丢了爱情丢了你"},
  • {url:'http://cctv3.qiniudn.com/cty.mp3',title:"闯天涯"}
  • ];
  • $("#audioBtn").click(function(){
  • if(music.paused){music.play();
  • $("#audioBtn").removeClass("pause").addClass("play");
  • }else{music.pause();
  • $("#audioBtn").removeClass("play").addClass("pause");}
  • });
  • function randomMusic(){
  • var isone=$("#bgMusic").attr('src');
  • var noone=musicArr[parseInt(Math.random()*musicArr.length)];
  • if (noone.url==isone){var noone=musicArr[parseInt(Math.random()*musicArr.length)];}
  • $("#bgMusic").attr('src',noone.url);
  • $("#audioBtn").attr('title',noone.title);
  • }
  • randomMusic();
  • $("#bgMusic").on('ended',function(){
  • randomMusic();
  • });
  • });
 

/////

加载完成之后再播放音乐

html:

<audio id="bgMusic" src="" loop="loop"></audio>

js:

//控制音乐播放

var musicbg = document.getElementById("bgMusic");
$("#music").click(function(){
if(musicbg.paused){
musicbg.play();
$("#music").removeClass("pause").addClass("play");
}else{
musicbg.pause();
$("#music").removeClass("play").addClass("pause");
}
});

//页面加载完成之后调用finish方法

this.finish=function () {

var audioUrl = "js/music.mp3";//音频路径
//调用方法
_this.loadAudio(audioUrl,function(){

//加载层消失,内容层显示

_this.loadingBox.hide();
$(".text-center").show();

//音乐

$('#bgMusic').attr("src",audioUrl);

var musicbg = document.getElementById("bgMusic");
musicbg.play();

});

}

31.JS实现控制HTML5背景音乐播放暂停的更多相关文章

  1. JS实现控制HTML5背景音乐播放暂停

    首先在网页中嵌入背景音乐,html5代码为: <script src="http://wuover.qiniudn.com/jquery.js"></script ...

  2. Cocos2d-x中背景音乐播放暂停与继续

    背景音乐播放暂停与继续似乎我们很少使用,事实上也正是如此,背景音乐播放暂停与继续实例代码如下: SimpleAudioEngine::getInstance()->pauseBackground ...

  3. js控制html5 audio的暂停、播放、停止

    <!DOCTYPE HTML> <html> <head> <meta charset="utf-8"> <meta name ...

  4. HTML5背景音乐的暂停与播放

    HTML代码:     <audio id="myaudio" loop="loop" preload="auto" autoplay ...

  5. JS控制flash的播放

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xht ...

  6. js控制html5 【video】标签中视频的播放和停止

    需求:页面中有2个普通按钮a,b.还有一个video标签,能成功播放出视频..我想要的效果是,点击a按钮,视频开始播放,点击b按钮,视频播放停止!!!<br><br>----- ...

  7. html5 audio的暂停与播放

    在html5里,audio是新增的功能.它方便了用户. 大多数音频是通过插件(比如 Flash)来播放的.然而,并非所有浏览器都拥有同样的插件. HTML5 规定了一种通过 audio 元素来包含音频 ...

  8. 使用jQuery播放/暂停 HTML5视频

    文章来自:http://blog.okbase.net/jquery2000/archive/4485.html 我尝试用jQuery控制HTML5视频,两个视频分别在两个tab中,我希望点中tab后 ...

  9. apk支持html video控制 ,是播放状态就暂停,暂停状态就播放

    apk支持html video控制 <!DOCTYPE html> <html> <body> <div style="text-align:cen ...

随机推荐

  1. hdfs 操作 入门api

    获取分布式文件系统 // 获取文件系统 @Test public void getFileSystem() throws Exception{ Configuration configuration ...

  2. Codeforces 835C - Star sky - [二维前缀和]

    题目链接:http://codeforces.com/problemset/problem/835/C 题意: 在天空上划定一个直角坐标系,有 $n$ 颗星星,每颗星星都有坐标 $(x_i,y_i)$ ...

  3. [No0000136]6个重要的.NET概念:栈,堆,值类型,引用类型,装箱,拆箱

    引言 本篇文章主要介绍.NET中6个重要的概念:栈,堆,值类型,引用类型,装箱,拆箱.文章开始介绍当你声明一个变量时,编译器内部发生了什么,然后介绍两个重要的概念:栈和堆:最后介绍值类型和引用类型,并 ...

  4. sql 一对多查询

    1. 一对多查询 查询departmentinfo字典下所有部门的人员数量 select * from departmentinfo a left join (select count(*) User ...

  5. PHP之Boolean

    Boolean布尔类型 这是最简单的类型.Boolean表达了真值,可以为true或者false. 语法 要指定一个布尔值,使用常量true或者false,两个都不区分大小写. 通常运算符所返回的Bo ...

  6. Xcode编译警告Assigning to 'id<XXXDelegat> ——Nullable' from incompatible type 'XXXView *const_strong'

    编译报警告 可能是 自定义分类使用协议时出现与父类协议的冲突 解决方法如下:    

  7. flash cs4 如何新增自定义控件

    1. 新增控件脚本* import gfx.controls.CoreList; import gfx.core.UIComponent; import gfx.controls.CheckBox; ...

  8. EF-CodeFirst-域模型配置

    之前说到CodeFirst会使用默认约定从域模型创建数据库,同时也提供了方法重写这些约定;有两种方法可以实现 使用数据注解属性 使用Fluent API 数据注解属性 数据注释是一种简单的基于属性的配 ...

  9. Django + Redis实现页面缓存

    目的:把从数据库读出的数据存入的redis 中既提高了效率,又减少了对数据库的读写,提高用户体验. 例如: 1,同一页面局部缓存,局部动态 from django.views import View ...

  10. 获取链接的参数,判断是否是微信打开,ajax获取数据

    //获取链接参数function GetQueryString(name) {    var reg = new RegExp("(^|&)" + name + " ...