中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

愛奇藝視頻小程序系統功能如何開發

發布時間:2022-03-15 10:46:51 來源:億速云 閱讀:181 作者:iii 欄目:開發技術

本文小編為大家詳細介紹“愛奇藝視頻小程序系統功能如何開發”,內容詳細,步驟清晰,細節處理妥當,希望這篇“愛奇藝視頻小程序系統功能如何開發”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

1.首頁的輪播圖

這里使用的是小程序的滑塊視圖容器swiper組件,用來做輪播圖那叫一個簡單方便

使用過愛奇藝小程序的朋友會發現首頁簡單介紹視頻信息的輪播圖是布局在頁面中間并且每一張圖片都不相連的,滑動時很是簡潔大方。一開始我是簡單的使用,將swiper設置了寬高并使之居中,就產生了下面的結果:只有中間的內容在滑動,并不是想要的效果

那看來即使swiper組件看起來簡單也要好好研究一番哪,看了文檔之后我發現swiper組件其實是swiper-item在滑動,并且它僅可放置在swiper組件中,寬高自動設置為100%。既然這樣,那就去設置swiper-item的寬度好了

swiper{
    width:100%;
}
swiper-item{
    width:80%;
}

emmm好像不太行,似乎每一個swiper-item總是那么分不開啊,那就去設置里面的內容的樣式吧

.info-box{
    width: 100%;
    margin: 0 60rpx;
}

總算這樣才做到了想要的效果。撒花~

2.宣傳圖跟著輪播圖改變

在這里是使用了swiperbindchange方法。只要滑動了就會觸發,并且有一個current代表當時滑動到第幾個。這樣想來,swiper好像一個數組,里面包含著很多的swiper-item

所以我們可以在js部分通過獲取到這個current值,在對應的圖片資源數組中遍歷并取出地址,換成宣傳圖的地址即可

//index.js
        moviepicChange(e) {
        const imgsUrlList = this.data.imgsUrlList; //圖片資源
        let bigImg = this.data.bigImg;
        let video_id = this.data.video_id;

        for (let i = 0; i < imgsUrlList.length; i++) {
            if (i == e.detail.current) { //如果current值與圖片數組索引值匹配到了,則
                bigImg = imgsUrlList[i].thumbnail; //換掉宣傳圖片地址
                video_id = imgsUrlList[i].video_id;
            }
        }
        this.setData({
            bigImg: bigImg,
            video_id
        })
    }

3.任意點擊視頻縮略圖即可跳轉到相關頁面

在這個功能里頭,數據處理是我碰到的一大難題了,因為沒有后端,我就想試圖模擬一下點擊一個圖片就發送視頻id,并由后端返回響應數據的操作,大致思路就是就是通過了一個“中間站”去處理。emmm 可能有一點笨笨的= =。

  1. 首先準備好來自Easy-Mock的數據接口

  2. 然后在視頻縮略圖上綁定一下事件,用data-傳遞想要用于查詢的參數

     <swiper-item data-vid="{{item.video_id}}" data-title="{{item.title}}" bindtap="openDetail"></swiper-item>
  3. 視頻詳情頁面獲取到傳過來的id之后就可以發起請求,因為wx.request是個異步操作,需要一點時間,此處我對wx.request進行了封裝,返回一個promise的辦法就可以把異步操作變成了同步的啦ヾ(?&deg;&nabla;&deg;?)??

     //video-detail.js
     requestVideo: function(num = 0) {
     util.request({ //封裝的util.request方法
             url: `https://www.easy-mock.com/mock/5b0c37bed0e51c310ce24ab0/iqiyi/media#!method=get`,  //請求地址
             data: { // 請求參數
                 id: this.data.video_id,
                 tag: 'dramas',
                 langs: 'en'
             }
         })
         .then(res => { //res是返回的數據
             //對數據進行處理,之后便可通過數據綁定在頁面顯示響應內容
         })
     }

創建一個util工具文件夾,用于提供工具方法。這里就是我模擬后端傳回響應數據的地方,先在util.js內獲取所有的數據,再根據視頻詳情頁面發送過來的參數對已經獲得的數據進行處理,通過返回promise.then的操作在視頻詳情頁面獲得由util.js處理之后的數據。

//util.js    
let util = {
request(opt) {
    let options = Object.assign({},opt); //花括號是目標對象,后面的opt是源對象。進行對象合并:將源對象里面的屬性添加到目標對象中去,若兩者的屬性名有沖突,后面的將會覆蓋前面的
    let { url, data} = options; //結構成這兩個變量

    return new Promise((resolve, reject) => { //向請求發起頁面返回一個promise
        wx.request({ //發送請求
            url,
            data,
            success(res) { //請求到數據之后對數據進行處理
                let returnRes = [];
                if (data.hasOwnProperty('tag')) { 
                    let arr = res.data[data.tag];

                    if (data.hasOwnProperty('id')) { //如果請求參數中有tag,id則進行以下匹配
                        console.log(arr)
                        for (let i in arr) {
                            if (arr[i].video_id === data.id) { 
                                returnRes = arr[i]; //得到跟點擊的縮略圖相對應的視頻資源
                            }
                        }
                        resolve(returnRes)
                        return;
                    }
                    returnRes = arr;
                }
                resolve(returnRes)
            },
            fail(err) {
                reject(err)
            }
        })
    })
}
}

4.關鍵字搜索

  1. 首先是在搜索頁面獲取到關鍵字,之后作為請求參數使用上述封裝好util.request進行請求與數據處理

  2. 在util.js內獲取到所有數據之后,在眾多數據中通過RegExpObject.test(string)實現關鍵字的遍歷匹配

     //util.js
     if (data.hasOwnProperty('key')) { //如果請求參數是key
     const media = res.data;
     for (let i in media) { //遍歷匹配電影名
         for (let j in media[i]) {
             var re = new RegExp(data.key);
             if (re.test(media[i][j].title)) {
                 returnRes.push(media[i][j]); //得到匹配好的電影
             }
         }
     }
     resolve(returnRes)
     return;
     }
     resolve(returnRes)
  3. 搜索頁面使用util.request得到數據之后,搜索結果列表一項一項就可以顯示出來。重點是(敲黑板),一般來說點擊哪一項,在搜索結果頁面那一項就會排在最上面,那我就想要不然再建一個由點擊的的那一項作為第一項的查詢結果數組,將它存在本地然后在下一個頁面取出并顯示!

     //search.js
     clickResult: function(e) {
     let index = e.currentTarget.dataset.num; //點擊了第幾項
     let searchVal = this.data.searchVal; //關鍵詞
     let StorageResult = []; // 用于存在本地的數組
    
     let temp = [];
     const result = this.data.result;
    
     for (let i = 0; i < result.length; i++) {
         if (i == index) {
             temp = result.splice(i, 1); //取出點擊的那一項
         }
     }
     StorageResult = temp;
     for (let i in result) {
         StorageResult = [...StorageResult, result[i]] //將點擊的那一項作為數組首位,其他搜索結果再依次放入
     }
     wx.setStorage({ //在本地緩存搜索結果
         key: 'searchResult',
         data: StorageResult,
         success: function(res) {
             wx.navigateTo({
                 url: `search-result/search-result?key=${searchVal}` //跳轉到下一個頁面
             })
         }
     })
     }
  4. 另外,搜索結果會順帶把集數羅列出來,那就需要實現點哪集就在視頻詳情頁定位到哪集的功能

  • 先在wxml里通過data-把id、集數、標題傳到下一個頁面,在onload里頭獲取集數

      //video-detail.js
      onLoad: function(option) {
      this.setData({
          video_id: option.id,
          mediaList: null,
      })
      wx.setNavigationBarTitle({ //設置導航條名稱
          title: option.title
      })
      if (option.hasOwnProperty('num')) { //調用請求資源方法傳入集數
          this.requestVideo(option.num);
      } else {
          this.requestVideo();
      }
      }
  • 請求所有視頻資源之后并遍歷,把當前播放地址設為選中的那集

      requestVideo: function(num = 0) { //沒有選擇集數,則集數默認是0
      util.request({
             ...(略)
          })
          .then(res => {
              this.setData({
                      mediaList: res,
                      isLoading: false,
                      playerUrl: res.drama_num[num].video_url //修改播放地址
                  })
              this.pickNum(num); //改變集數選擇狀態
          })
      }
  • 用于改變集數選擇狀態

      pickNum: function(num) {
      for (let i of mediaList.drama_num) {
          i.selected = parseInt(i.drama_id) === parseInt(num) + 1 //如果選擇的集數與視頻資源的id一樣就改變該集的選中狀態
          if (i.selected) {
              playerUrl = i.video_url
          }
      }
      this.setData({
              mediaList,
              playerUrl
          })
      }

讀到這里,這篇“愛奇藝視頻小程序系統功能如何開發”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

乃东县| 周宁县| 上饶市| 长兴县| 永川市| 永丰县| 汉阴县| 衡阳县| 巍山| 纳雍县| 连城县| 彩票| 溧水县| 攀枝花市| 鸡东县| 福建省| 黄石市| 宁南县| 奈曼旗| 南昌县| 龙泉市| 泰宁县| 霞浦县| 宝山区| 镇江市| 青龙| 五家渠市| 米泉市| 宁陵县| 栖霞市| 呼玛县| 门头沟区| 马公市| 义乌市| 竹北市| 龙陵县| 涟水县| 利川市| 肃南| 镇安县| 庄河市|