背景音樂部分跟視頻播放部分出了點小問題,后來解決了,記錄一下。
背景音樂基本需求:在背景右上角定位一個音樂開關,打開H5時自動播放,播放時開關一直旋轉,點擊關閉音樂,開關不旋轉,還有如果播放視頻時,音樂自動停止。
[TOC]
## 前言
做h5專題的時候我們經常需要添加背景音樂,重復的添加audio標簽和控制已經讓人厭煩,先本人本著社會主義精神將背景音樂所需要的代碼進行封裝(其實很早之前華哥就做過了)。使用的是函數式封裝,而沒有使用對象,因為感覺太簡單不需要創建對象。
## 使用方法
~~~
<script src="http://www1.pconline.com.cn/zt/20160621/Gbgmusic_min.js"></script>
<script>
var bgMusic = new GbgMusic("http://www1.pconline.com.cn/zt/20160608/biyadi/bg.mp3");
</script>
~~~
## API說明
### 創建背景音樂對象:
如果手機支持背景音樂自動播放,則創建完對象后自動播放音樂。如果手機不支持自動播放背景音樂,則需要網友點擊下頁面或者點擊下音樂播放按鈕。
~~~
var bgMusic = new GbgMusic(src,top,left); //top、left可以省略默認是15px;
~~~
### 阻止自動播放
~~~
bgMusic.stopAuto();
~~~
### 停止音樂
~~~
bgMusic.pause();
~~~
### 播放音樂
~~~
bgMusic.play();
~~~
### 返回dom形式的音樂對象
~~~
bgMusic.getAudio();
~~~
## demo
http://www1.pconline.com.cn/zt/20160621/bgmusic.html
## 插件地址
壓縮版插件地址:http://www1.pconline.com.cn/zt/20160621/Gbgmusic_min.js
## 源代碼
~~~
/*初始化GbgMusic獲取背景音樂對象*/
function GbgMusic(src,top,right){
return new _GbgMusic(src,top,right);
}
function _GbgMusic(src,top,right){
this.src=src;
this.top=top;
this.right=right;
this.audio=null;
this.musicBtn=null;
this.hasStop=false;
this.init();
}
//背景音樂初始化,背景音樂默認是自動播放且循環播放
_GbgMusic.prototype.init=function(){
var musicBtn=this.musicBtn=document.createElement("div"),
audio = this.audio=document.createElement("audio"),
styleNode = document.createElement("style");
styleNode.innerText=".GmusicBtn{width: 80px;height: 80px;overflow: hidden;position: absolute;top:"+(this.top?this.top:15)+"px;right:"+(this.right?this.right:15)+"px;z-index: 1000;background-image: url(http://www1.pconline.com.cn/zt/20160309/changma/image/other/playerBtn.png);background-repeat: no-repeat;background-position:0px 0px;}@-webkit-keyframes Grotate{0%{-webkit-transform:rotate(0deg);}100%{-webkit-transform:rotate(360deg);}}.Grotate{-webkit-animation:Grotate 5s linear infinite;}";
var bodyNode=document.getElementsByTagName("body")[0];
var frag = document.createDocumentFragment();
frag.appendChild(styleNode);
frag.appendChild(musicBtn);
frag.appendChild(audio);
bodyNode.appendChild(frag);
musicBtn.className="GmusicBtn Grotate";
audio.src=this.src;
audio.setAttribute("loop","loop");
audio.setAttribute("autoplay","autoplay");
var that = this;
bodyNode.addEventListener("touchstart",function(){
if(!that.hasStop){
that.musicPlay();
}
bodyNode.removeEventListener("touchstart",arguments.callee);
},false)
musicBtn.addEventListener("touchstart",function(e){
e.stopPropagation();
if(!audio.paused){
that.musicPause();
}else{
that.musicPlay();
}
},false)
}
_GbgMusic.prototype.musicPlay=function(){
var audio=this.audio,
musicBtn=this.musicBtn;
if(audio.paused){
musicBtn.style.backgroundPositi 0px";
musicBtn.className="GmusicBtn Grotate";
audio.play();
}
}
_GbgMusic.prototype.musicPause=function(){
var audio=this.audio,
musicBtn=this.musicBtn;
if(!audio.paused){
this.hasStop=true;
musicBtn.style.backgroundPositi -80px";
musicBtn.className="GmusicBtn";
audio.pause();
}
}
//停止自動播放
_GbgMusic.prototype.stopAuto=function(){
var audio=this.audio,
musicBtn=this.musicBtn;
this.hasStop=true;
audio.removeAttribute("autoplay","autoplay");
musicBtn.style.backgroundPositi -80px";
musicBtn.className="GmusicBtn";
audio.pause();
}
// 播放音樂
_GbgMusic.prototype.play=function(){
this.musicPlay();
}
// 暫停音樂
_GbgMusic.prototype.pause=function(){
this.musicPause();
}
//返回audio對象
_GbgMusic.prototype.getAudio=function(){
return this.audio;
}
~~~
## 參考網址
H5頁面背景音樂,C33 360°旋轉效果
https://www.cnblogs.com/shizq/p/5658539.html
H5分享頁面背景音樂及播放視頻
https://blog.csdn.net/weixin_42423019/article/details/80733601
- Layer無刷新不跳轉彈框提示信息
- 整合ThinkPHP+實用代碼
- TP整合Layer插件實現無刷新
- 自定義助手函數
- 添加信息失敗后不跳轉
- 三種無限級分類
- TP常用代碼
- 自定義公共函數
- TP模型管理專題
- TP模型管理之添加模型
- sfox_newmodel.sql
- TP模型管理之刪除模型
- TP模型管理之編輯模型
- TP模型管理之字段添加
- sfox_newmodel.sql_edit
- layer_hplus.js_edit
- TP模型管理之字段刪除
- TP模型管理之字段編輯
- TP模型管理之預覽模型
- TP模型管理之公共函數
- layer_hplus.js_修訂一
- TP模型管理之預覽模型靜態頁
- 后臺內容管理系統
- 分類樹顯示
- 內容列表顯示
- 信息發布
- 編輯信息
- layer_hplus.js
- myJs第一版
- myJs第二版
- myJs第三版
- myJs第四版
- TP5插件用法
- Datatables
- WebUploader
- bootstrap-fileinput
- UEditor
- 簡單調用
- 路徑問題
- 跨域多圖上傳
- 跨域單圖上傳
- UEditor圖片跨域上傳解決方案
- 定制工具欄圖標
- ajaxFileUpload
- LayUI
- 圖片上傳
- layui分頁
- 搜索頁
- 搜索優化及刪除
- Uploadify
- TP5前端應用
- 靜態首頁
- 前臺首頁功能實現
- 自定義標簽庫
- 前臺模板繼承應用
- 首頁自定義標簽改進
- 文章內容頁
- 自定義標簽改進
- 自定義標簽修正
- 圖片等比例自動縮放
- 后臺權限管理
- 角色管理
- 規則管理
- 權限設置
- 會員管理
- 權限管理
- 前臺登錄注冊功能
- 注冊登錄
- 阿里大于手機注冊
- 阿里大于升級阿里云短信服務
- 自動登錄完成
- PHP異位或加密實現自動登陸
- 微信開發
- 分享接口
- 靜態頁面實現微信分享
- 動態頁微信分享
- 頁面靜態化
- 1-全站靜態化前期配置
- 2-鏈接地址靜態化
- TP5常用片段代碼
- 加載靜態資源路徑與常量
- thinkphp5預定義常量
- 刪除某文件夾的內容
- 解壓插件包
- 異步提交插件
- 其他功能
- 背景音樂
- 手機訪問PC網站自動跳轉到手機網站代碼
- 手機微信音樂MP3播放器
- 后盾之網頁背景音樂
- 播放器寬度自適應
- 前臺首頁數據調用
- 視頻列表
- 搜索分頁
- H5解決蘋果(IOS)不能自動播放音樂
- 清空緩存
- 文件處理常識
- 刪除路徑下的所有文件夾和文件
- 一鍵清空緩存
- 評論留言
- 格式化時間
- 替換微博內容的URL地址@用戶與表情
- PHP正則理解
- jQuery評論插件
- TP空操作
- TP路由
- 跨域訪問
- 設置請其頭允許跨域請求
- 模板前臺判斷手機訪問跳轉手機網址代碼
- PHP遍歷一個文件夾下所有文件和子文件夾
- PHP獲取視頻的第一幀與時長
- TP5數據庫
- 鏈式操作原理
- update替換字段部分內容
- 后臺開發
- 后臺登錄頁居中顯示
- TP5自帶驗證碼
- JS & JQuery專題
- 二級城市聯動菜單
- 模板引擎
- 混合模板編譯
- 黃永成TP微博開發
- 消息推送
- memcache安裝
- 插件開發
- 插件介紹
- 插件鉤子
- 淺談初步理解鉤子
- 插件鉤子(hooks)分析
- 插件鉤子簡單理解
- 控制器調用插件
- 鉤子通用處理函數
- 插件基類代碼
- 插件測試代碼
- 淺談鉤子與插件
- 技術綜合
- 常用代碼
- PHP
- 56個PHP開發常用代碼片段(上)
- 56個PHP 開發常用代碼片段(中)
- 56個PHP 開發常用代碼片段(下)
- sublime text安裝自動補全注釋的插件
- 影音視頻開發
- 視頻
- H5視頻直播掃盲
- 音樂
- 語音
- PHP實現語音播報功能
- MUI
- 窗體操作