## 知識點
1、觸摸事件
2、旋轉的音樂圖標
3、背景音樂效果的控制
4、移動端css兼容性的解決思路
5、移動端音樂自動播放的處理方法
6、相關視頻下載
[TOC]
## 一、觸摸事件
HTML5實戰與剖析之觸摸事件(touchstart、touchmove和touchend)
HTML5中新添加了很多事件,但是由于他們的兼容問題不是很理想,應用實戰性不是太強,所以在這里基本省略
咱們只分享應用廣泛兼容不錯的事件,日后隨著兼容情況提升以后再陸續添加分享。
今天為大家介紹的事件主要是觸摸事件:touchstart、touchmove和touchend。
touchstart事件:當手指觸摸屏幕時候觸發,即使已經有一個手指放在屏幕上也會觸發。
touchmove事件:當手指在屏幕上滑動的時候連續地觸發。在這個事件發生期間,調用preventDefault()事件可以阻止滾動。
touchend事件:當手指從屏幕上離開的時候觸發。
touchcancel事件:當系統停止跟蹤觸摸的時候觸發。關于這個事件的確切出發時間,文檔中并沒有具體說明,咱們只能去猜測了。
后盾CSS3視頻教程
https://www.bilibili.com/video/av30185117/?p=68
后盾CSS3視頻教程
http://www.houdunwang.com/houdunren18_lesson_254?vid=11990
懶人原生css3可控旋轉音樂播放按鈕
http://www.lanrenzhijia.com/js/css3/3064.html
## 二、旋轉的音樂圖標
### 1、結構
~~~
<img src="../static/index/default/images/music.svg" id="mpic">
<audio loop="" src="https://res1.eqh5.com/2a2bdb15b9e545f28396cb68fe75054a.mp3" autoplay="" preload="" id="music"></audio>
~~~
### 2、引入文件
樣式文件
jQuery文件
### 3、功能實現
~~~
$('#mpic').on('touchstart',function(){
console.log('touchstart');
});
$('#mpic').on('touchend',function(){
console.log('touchend');
})
~~~
## 三、背景音樂效果的控制
### 暫停或切換
當m=1時,背景旋轉,音樂播放
當m=2時,背景停止,音樂停止
~~~
<script>
var m=1;
$('#mpic').on('touchstart',function(){
if (m==1) {
$('#mpic').css({
'animation-play-state':'paused',
});
m=2;
}else{
$('#mpic').css({
'animation-play-state':'running',
});
m=1;
}
});
</script>
~~~
### 暫停播放音樂
~~~
原生寫法pause()
document.getElementById('music').pause();
jQuery對象轉換原生寫法
$('#music')[0].pause();
~~~
### 播放音樂
~~~
$('#music')[0].play();
~~~
### 完整代碼
~~~
<script>
var m=1;
$('#mpic').on('touchstart',function(){
if (m==1) {
$('#mpic').css({
'animation-play-state':'paused',
});
$('#music')[0].pause();
m=2;
}else{
$('#mpic').css({
'animation-play-state':'running',
});
$('#music')[0].play();
m=1;
}
});
</script>
~~~
## 四、移動端css兼容性的解決思路
~~~
#mpic{
width: 45px;
height: 45px;
position: fixed;
left: 62px;
top: 88px;
z-index: 200;
-webkit-animation: r 5s linear infinite;
-moz-animation: r 5s linear infinite;
-o-animation: r 5s linear infinite;
animation: r 5s linear infinite;
}
@-webkit-keyframes r {
from{
-webkit-transform: rotate(0deg);
}
to{
-webkit-transform: rotate(360deg);
}
}
@-moz-keyframes r {
from{
-moz-transform: rotate(0deg);
}
to{
-moz-transform: rotate(360deg);
}
}
@-o-keyframes r {
from{
-o-transform: rotate(0deg);
}
to{
-o-transform: rotate(360deg);
}
}
@keyframes r {
from{
transform: rotate(0deg);
}
to{
transform: rotate(360deg);
}
}
~~~
## 五、移動端音樂自動播放的處理方法
所有移動端都是禁止自動播放的,即禁止autoplay屬性
### 1、去掉HTMLautoplay屬性
~~~
<audio loop="" src="https://res1.eqh5.com/2a2bdb15b9e545f28396cb68fe75054a.mp3" id="music"></audio>
~~~
### 2、CSS添加停止屬性
~~~
#mpic{
width: 45px;
height: 45px;
position: fixed;
left: 62px;
top: 88px;
z-index: 200;
-webkit-animation: r 5s linear infinite;
-moz-animation: r 5s linear infinite;
-o-animation: r 5s linear infinite;
animation: r 5s linear infinite;
animation-play-state:paused;
}
@-webkit-keyframes r {
from{
-webkit-transform: rotate(0deg);
}
to{
-webkit-transform: rotate(360deg);
}
}
@-moz-keyframes r {
from{
-moz-transform: rotate(0deg);
}
to{
-moz-transform: rotate(360deg);
}
}
@-o-keyframes r {
from{
-o-transform: rotate(0deg);
}
to{
-o-transform: rotate(360deg);
}
}
@keyframes r {
from{
transform: rotate(0deg);
}
to{
transform: rotate(360deg);
}
}
~~~
### 3、功能實現
~~~
<script>
var m=2;
document.ontouched = function(){
$('#mpic').css({
'animation-play-state':'running',
});
$('#music')[0].play();
m=1;
document.ontouched = null;
}
$('#mpic').on('touchstart',function(){
if (m==1) {
$('#mpic').css({
'animation-play-state':'paused',
});
$('#music')[0].pause();
m=2;
}else{
$('#mpic').css({
'animation-play-state':'running',
});
$('#music')[0].play();
m=1;
}
});
</script>
~~~
### 4、升級事件
可以改寫成one事件:鍵盤事件和單擊事件,限制只執行一次
~~~
document.one('touchend',function(){
$('#mpic').css({
'animation-play-state':'running',
});
$('#music')[0].play();
m=1;
};
)
~~~
## 六、相關視頻下載
1、騰訊微云
~~~
已上傳至微云
~~~
2、百度網盤
- 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
- 窗體操作