1、wxml部分代码 ,主要是利用swiper 标签滑动切换,事件处理,具体参数说明可以去小程序官网文档查看。https://developers.weixin.qq.com/miniprogram/dev/component/swiper.html
2、js 部分
Page({ /** * 页面的初始数据 */ data: { isPlay:true, video_id:"video_0", videoList:[], pageShow:false, current:0, // 当前滑块 vertical:false, // 滑块方向 offset:0, page_index:1, firstRequest:true, isRequest:true, // 是否正在发起请求,控制不会多次滑动出发接口请求多次问题 page_count:5, isHaveData:true // 判断接口返回的还有没有数据,没有设置成false }, /** * 生命周期函数--监听页面加载 */ onl oad: function (options) { this.getShortVideo(); }, // current 改变时会触发 change 事件 bindchange(e){ this.setData({ current: e.detail.current }) this.swiperVideo(e); if(this.data.isHaveData && e.detail.current >= this.data.videoList.length-2 && !this.data.isRequest){ this.setData({ page_index: this.data.page_index+1 },res=>{ this.setData({ offset: (this.data.page_index-1) * this.data.page_count, isRequest: true, }) this.getShortVideo(); }) } }, // 点击视频暂停活播放 clickVideo(e){ //这里的vid是视频的id,因为这里我是用接口传数据的,里面有视频id let vid = e.currentTarget.id; let indexVideoContext = wx.createVideoContext(vid) if(this.data.isPlay){ indexVideoContext.pause(); }else{ indexVideoContext.play(); } this.setData({ isPlay: !this.data.isPlay }) }, // 获取视频列表 getShortVideo(){ wx.cloud.callFunction({ name:"short-video", data:{ type:"checkList", offset: this.data.offset, page_count: this.data.page_count } }).then(res=>{ console.log(res) if(this.data.page_index==1){ this.setData({ indexVideo:res.result.list[0] }) } // 请求接口的数据和每次获取条数如果不相等,说明后面已经没有数据了 isHaveData: false if(res.result.list.length!=this.data.page_count){ this.setData({ isHaveData:false }) } this.setData({ isRequest: false, videoList: [ ...this.data.videoList, ...res.result.list], }) }) }, // 滑动切换视频 swiperVideo(e){ //这里的vid是视频的id,因为这里我是用接口传数据的,里面有视频id let vid = `video_${e.detail.current}`; // 上个一视频id var prev_id = this.data.video_id; // 停止山一个视频播放 wx.createVideoContext(prev_id).pause(); this.setData({ firstRequest:false, video_id:vid, isPlay:true }) // 延迟500ms,再播放本视频 setTimeout(function(){ wx.createVideoContext(vid).play(); },500) }, })
以上是主要代码部分,如有不明白的留言,相互探讨交流
(完结)
下面是我的小程序实现的效果,可以扫码看看,也可以微信搜索小程序名《最新热门信息汇总》