微信小程序 video-swiper 修改暂停播放第一屏

最近在做一个小程序,因为小程序涉及到video-swiper开发的很少,在网上看到能够详细解决问题的少之又少,都是自己按照逻辑摸索出来的,用video-swiper开发,引入的是npminstall@miniprogram-component-plus/video-swiper。持续踩坑中,修改了原组件视频无法在第一个视频播放、无法点击一次播放暂停,完善组件中分页数据新建视频dom的功能。

1、修改了@miniprogram-component-plus/video-swiper组件,发布了新的组件https://www.npmjs.com/package/miniprogram-component-video

2、npm install miniprogram-component-video,

3、在小程序工具中构建npm

4、引入miniprogram-component-video

"usingComponents": {

    "mp-video-swiper": "miniprogram-component-video"

  }

5、从数据库拿到数据后,新数据放到videoListNewDom中,传到子组件中,旧视频数据加上新数据放到videoList中

6、子组件中的properties接受到videoListNewDom数据,新建视频dom

7、setvideoList为了分享后从其他地方通过id进入页面再次获取数据后,再获取新数据后给数据去重。

8、wx.setStorageSync('slidecurrent', e.detail.current)为了记录当前页面current,

进入视频页面时设置为0

9、上面第8点的截图中绑定slide事件,监听滑动视频的当前位置,给当前视频赋评论等数据,到最后一页时,重新加载数据

10、点击让视频播放、暂停

要在mp-video-swiper 上加一个id,bindtap="change",playShow为了显示隐藏播放按钮


change: function(){

      var vvideo = this.selectComponent("#video-swiper-id")

      var current_video = vvideo.data._videoContexts[vvideo.data._last];

      setTimeout(()=>{

        if(this.data.playShow){

          current_video.play()

          this.setData({

            playShow: false

          })

        }else{

          current_video.pause()

          this.setData({

            playShow: true

          })

        }

      })

      }

11、播放第一屏,在视频元数据加载完成时触发。因为_last在组件中为1,所以在这里给赋值为0;


if (wx.getStorageSync('slidecurrent') === 0) {

        var vvideo = this.selectComponent("#video-swiper-id")

        vvideo.data._last = 0; //如果不赋值为0,就不是从第一条播放

        vvideo.data._invalidDown = 1;

        vvideo.playCurrent(0)

      }

你可能感兴趣的:(微信小程序 video-swiper 修改暂停播放第一屏)