[TOC]
## 要點(小程序升級了)
### 點擊事件
```
onMusic() {
if (this.data.isPlay) {
audio.pause();
this.setData({
isPlay: false
})
}
else {
// audio.title = this.properties.title;
audio.src = this.properties.musicUrl;
this.setData({
isPlay: true
})
}
}
```
### 恢復音樂函數
```
//當重新進入頁面 恢復音樂 播放或暫停
_recoveryMusic() {
//如果監聽到的src 與 properties的musicUrl相同時 讓音樂播放
if (audio.src == this.properties.musicUrl) {
this.setData({
isPlay: true
})
}
//如果監聽到的 paused(audio的屬性) 為true時 設置isPlay為false
if (audio.paused) {
this.setData({
isPlay: false
})
}
},
```
### 監聽音樂函數 讓監聽與播放保持一致
```
//監聽音樂
_monitorMusic() {
//監聽音頻播放事件
audio.onPlay(() => {
this.setData({
isPlay: true
})
})
//監聽音頻暫停事件
audio.onPause(() => {
this.setData({
isPlay: false
})
})
//監聽音頻停止事件
audio.onStop(() => {
this.setData({
isPlay: false
})
})
//監聽音頻自然播放至結束的事件
audio.onEnded(() => {
this.setData({
isPlay: false
})
})
}
```
### 調用函數
```
//當組件觸發 attached 生命周期時,會依次觸發 my-behavior 中的 attached 生命周期函數和 my-component 中的 attached 生命周期函數
attached() {
this._recoveryMusic();
this._monitorMusic();
}
```
# 完整js
```
// components/classic/music/index.js
const audio = wx.getBackgroundAudioManager()
Component({
/**
* 組件的屬性列表
*/
properties: {
content: {
type: String
},
image: {
type: String
},
musicUrl: {
type: String
}
},
/**
* 組件的初始數據
*/
data: {
isPlay: false
},
/**
* 組件的方法列表
*/
methods: {
onMusic() {
if (this.data.isPlay) {
audio.pause();
this.setData({
isPlay: false
})
}
else {
// audio.title = this.properties.title;
audio.src = this.properties.musicUrl;
this.setData({
isPlay: true
})
}
},
//當重新進入頁面 恢復音樂 播放或暫停
_recoveryMusic() {
//如果監聽到的src 與 properties的musicUrl相同時 讓音樂播放
if (audio.src == this.properties.musicUrl) {
this.setData({
isPlay: true
})
}
//如果監聽到的 paused(audio的屬性) 為true時 設置isPlay為false
if (audio.paused) {
this.setData({
isPlay: false
})
}
},
//監聽音樂
_monitorMusic() {
//監聽音頻播放事件
audio.onPlay(() => {
this.setData({
isPlay: true
})
})
//監聽音頻暫停事件
audio.onPause(() => {
this.setData({
isPlay: false
})
})
//監聽音頻停止事件
audio.onStop(() => {
this.setData({
isPlay: false
})
})
//監聽音頻自然播放至結束的事件
audio.onEnded(() => {
this.setData({
isPlay: false
})
})
}
},
//當組件觸發 attached 生命周期時,會依次觸發 my-behavior 中的 attached 生命周期函數和 my-component 中的 attached 生命周期函數
attached() {
this._recoveryMusic();
this._monitorMusic();
}
})
```
- 開發環境及接口
- 0.豆瓣接口
- 1.開發環境配置
- 2.一些相關文檔
- 小程序實例效果
- 第0節、TodoList
- 第一節、豆瓣相關
- 1、tabBar的配置及導航加標題
- 2、數據加載及下拉加載
- 3、加載相關
- 4、輪播
- 5、星星評分
- 第二節、音樂播放相關
- 1.點擊收藏分享
- 2.音樂播放
- 初始版
- 組件版
- 組件加強版
- 3.點贊
- 點贊初級版
- 點贊第二版
- 5.左右按鈕
- 6.緩存
- 第三節、補充
- 地圖
- 點擊拍照換圖
- 掃一掃
- 小程序語法
- 第一節 、HTTP的封裝
- 0.http請求
- 1.function封裝
- 2.class封裝http
- 3.promise封裝
- 4.config地址
- 第二節、組件
- 2.組件單獨設置樣式
- 3.一些有意義的標簽
- 4.behavior
- 5.SLOT
- 6.左右按鈕
- 5.點贊組件
- 6.用戶授權
- 圖片按鈕 如分享
- 第三節、api
- 1.頁面跳轉
- 獲取input里的值
- 1.添加評論
- 2.搜索框
- 3. 獲取input里的值
- 2.設置緩存
- 3.模態框,彈出框
- 4.分享showActionSheet
- 5.定義全局的數據
- 2. 基礎知識
- 1.setData
- 2.文件結構
- 3.wxml語法
- 第一節 數據綁定
- 第二節 列表渲染
- 第三節 條件渲染
- 第四節 模板
- 第五節 事件
- 第六節 引用
- 4.wxs
- 1.文本縮進問題
- 5.小程序中遇到的wxss 問題
- 1.width100%越界問題
- 廢棄的文件
- 一個完整的小程序
- 1.啟動頁面
- 2.yuedu輪播+封裝及數據調用
- yuedu的詳情頁
- 3.電影
- movie-more
- web-view