微信小程序音樂播放器,音樂播放器檢索頁制作(下)
檢索頁 (下)
到目前為止,我們已經(jīng)完成了檢索頁所有的布局和格式文件,也完成了所有的數(shù)據(jù)請求函數(shù),現(xiàn)在我們需要將這些串聯(lián)起來,實現(xiàn)這三部分間的切換。
總結(jié)一下我們需要完成的邏輯有:
- 點擊熱門關鍵字,頁面內(nèi)容變成搜索結(jié)果頁(需要請求網(wǎng)絡,用我們寫好的getSearchMusic方法),輸入框內(nèi)顯示點擊的關鍵字,同時這個關鍵字加入歷史搜索結(jié)果。
- 在頁面內(nèi)容為熱門關鍵字的時候,點擊輸入框使其獲得焦點時,頁面內(nèi)容變成歷史記錄。
- 點擊歷史記錄文字,內(nèi)容變成搜索結(jié)果(請求網(wǎng)絡),輸入框顯示這個記錄。
- 點擊歷史記錄每條末尾的“X”,刪除這一條記錄,當所有記錄全部刪除或點擊了“清除歷史記錄”選項,內(nèi)容變?yōu)闊衢T關鍵字。
- 輸入框內(nèi)的內(nèi)容被全部刪除后,也返回熱門關鍵字。
- 點擊確認按鈕,內(nèi)容變?yōu)樗阉鹘Y(jié)果頁,同時加入歷史記錄。
-
點擊搜索結(jié)果的item,頁面轉(zhuǎn)到專輯頁或音樂播放頁。
實現(xiàn)這些邏輯的相關事件我們已經(jīng)在頁面里注冊好了,在具體實現(xiàn)這些事件之前,我們先寫一個函數(shù)——將字符串加入到歷史記錄。
這個函數(shù)很簡單,我們在寫歷史記錄頁面時,已經(jīng)用到了historySearchs這個數(shù)組,所以添加時我們只有獲取這個數(shù)組,然后將要添加的詞push到數(shù)組里,然后用setData更新頁面就可以了。
- addHistorySearchs: function (key) {
- var historySearchs = this.data.historySearchs;
- historySearchs.push(key);
- this.setData({
- historySearchs: historySearchs
- })
- },
但是這樣做的問題是當用戶多次搜索相同內(nèi)容時,數(shù)組內(nèi)就會多次加入同樣的詞,導致我們的歷史記錄列表里出現(xiàn)重復內(nèi)容,這顯然是不合理的,所以我們在每次push前,需要判斷數(shù)組內(nèi)是否已經(jīng)含有這個詞。
- findHistorySearchs: function (key) {
- var historySearchs = this.data.historySearchs;
- for (var i = 0; i < historySearchs.length; i++) {
- if (historySearchs[i] == key) { return false; }
- }
- return true;
- },
創(chuàng)建新的函數(shù),這個函數(shù)會遍歷historySearchs數(shù)組,如果存在相同項則返回false,沒有相同的返回true。
然后我們更改我們的addHistorySearchs方法:
- addHistorySearchs: function (key) {
- var historySearchs = this.data.historySearchs;
- if (this.findHistorySearchs(key)) {
- historySearchs.push(key);
- this.setData({
- historySearchs: historySearchs
- })
- }
- },
有個這個方法后,我們開始逐條完成我們的事件代碼。
將所有更新頁面有關變量添加到data里:
- data: {
- slider: [],
- indicatorDots: true,
- autoplay: true,
- interval: 5000,
- duration: 1000,
- radioList: [],
- currentView: 1,
- topList: [],
- hotkeys: [],
- showSpecial: false,
- special: { key: '', url: '' },
- searchKey: '',
- searchSongs: [],
- zhida: {},
- showSearchPanel: 1,
- historySearchs: [],
- },
熱門關鍵詞的點擊事件:
- hotKeysTap: function (e) {
- var dataSet = e.currentTarget.dataset;
- var key = dataSet.key; //獲取點擊的關鍵詞
- var self = this;
- if (key != '') { //判斷是否為空
- self.addHistorySearchs(key); //調(diào)用我們寫好的方法,加入歷史記錄
- self.setData({
- searchKey: key, //為輸入框內(nèi)添加文字
- showSearchPanel: 3, //顯示內(nèi)容切換為搜索結(jié)果
- });
- MusicService.getSearchMusic(key, function (data) { //請求網(wǎng)絡數(shù)據(jù)
- if (data.code == 0) {
- var songData = data.data;
- self.setData({ //將獲得的數(shù)據(jù)添加到相應數(shù)組里
- searchSongs: songData.song.list,
- zhida: songData.zhida
- });
- }
- });
- }
- },
輸入框獲取焦點事件:
- bindFocus: function (e) {
- var self = this;
- if (this.data.showSearchPanel == 1) { //判斷內(nèi)容是否為熱門關鍵詞
- self.setData({
- showSearchPanel: 2 //切換到歷史記錄
- })
- }
- },
歷史記錄文字的點擊事件:
- historysearchTap: function (e) {
- var dataSet = e.currentTarget.dataset;
- var key = dataSet.key; //獲取點擊的歷史記錄文字
- var self = this;
- self.setData({
- searchKey: key, //輸入框添加文字
- showSearchPanel: 3 //顯示搜索結(jié)果
- });
- MusicService.getSearchMusic(key, function (data) { //請求網(wǎng)絡,獲取搜索結(jié)果
- if (data.code == 0) {
- var songData = data.data;
- self.setData({
- searchSongs: songData.song.list,
- zhida: songData.zhida
- });
- }
- });
- },
歷史記錄結(jié)尾的“X”與“清除歷史記錄”的點擊事件:
- delHistoryItem: function (e) {
- var historySearchs = this.data.historySearchs;
- var dataSet = e.currentTarget.dataset; //獲取點擊的條目
- if (dataSet.index != 'undefined') {
- var _index = parseInt(dataSet.index); //獲取點擊條目為數(shù)組的第幾項
- historySearchs.splice(_index, 1); //從數(shù)組里刪除對應的條目
- this.setData({ //更新頁面
- historySearchs: historySearchs
- });
- if(historySearchs.length==0){ //如果歷史記錄里沒有數(shù)據(jù)了
- this.setData({
- showSearchPanel: 1 //切換到熱門關鍵字
- })
- }
- }
- },
- clearHistorySearchs: function () {
- this.setData({
- historySearchs: [], //清空歷史記錄數(shù)組
- showSearchPanel: 1 //切換到熱門關鍵字
- })
- },
輸入框輸入事件:
- bindKeyInput: function (e) {
- var self = this;
- self.setData({ //更新searchKey的值
- searchKey: e.detail.value
- });
- if (e.detail.value == "") { //如果值為空且當前未顯示熱門關鍵字
- if (this.data.showSearchPanel != 1) {
- self.setData({
- showSearchPanel: 1 //切換為熱門關鍵字
- })
- }
- }
- },
確認按鈕的點擊事件:
- searchOk: function (e) {
- var self = this;
- var searchKey = this.data.searchKey; //獲取searchKey的值
- if (searchKey != "") {
- self.setData({
- showSearchPanel: 3 //顯示搜索結(jié)果
- });
- self.addHistorySearchs(searchKey); //添加到歷史記錄
- MusicService.getSearchMusic(searchKey, function (data) {
- if (data.code == 0) {
- var songData = data.data;
- self.setData({
- searchSongs: songData.song.list,
- zhida: songData.zhida
- });
- }
- });
- }
- },
搜索結(jié)果item的點擊事件,分為專輯與歌曲兩種:
- zhidaTap: function (e) { //專輯的跳轉(zhuǎn)事件
- var dataSet = e.currentTarget.dataset;
- var mid = dataSet.id;
- app.setGlobalData({ 'zhidaAlbummid': mid }); //將專輯id保存為全局變量
- wx.navigateTo({ //頁面跳轉(zhuǎn)
- url: '../cdinfo/cdinfo'
- })
- },
- musuicPlay: function (e) { //歌曲的跳轉(zhuǎn)事件
- var dataSet = e.currentTarget.dataset;
- //TODO
- }
- },
歌曲的跳轉(zhuǎn)事件相對復雜(不只是要跳轉(zhuǎn),而且要加入播放列表),我們留到播放頁再更改這部分吧。
至此,首頁內(nèi)容全部完成(準確的說還缺少推薦頁與搜索結(jié)果頁向音樂播放頁跳轉(zhuǎn)的事件)。
上一節(jié):微信小程序小白項目開發(fā)案例之音樂播放器—檢索頁(中)
下一節(jié):微信小程序小白項目開發(fā)案例之音樂播放器——列表頁
第二部分:如何開通一個小商店