小程序视频列表中视频的播放与停止的示例代码
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了小程序视频列表中视频的播放与停止的示例代码,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3173字,纯文字阅读大概需要5分钟。
内容图文
![小程序视频列表中视频的播放与停止的示例代码](/upload/InfoBanner/zyjiaocheng/337/719ea3f967c2478dbb56d404562a5f7f.jpg)
效果类似一条视频的小程序,就是视频列表,然后每个视频上覆盖一张视频的封面图,点击封面图的播放按钮视频播放,点击别的视频的时候,停止播放当前视频,播放点击的视频。差不多是这样:
一条视频
首先上代码:
wxml
<block wx:for="{{videoList}}"> <view class='video-item'> <view class='wrapper'> <video class='video-video' wx:if='{{index==videoIndex}}' id='video{{index}}' autoplay='{{true}}' show-center-play-btn="{{false}}" src='{{item.resource_add}}'></video> <image class='video-video2' wx:if='{{index!=videoIndex}}' mode='aspectFill' src='{{item.coverimg}}'></image> <image class='videoPlay' wx:if='{{index!=videoIndex}}' data-index='{{index}}' bindtap='videoPlay' src='/images/icon/play.png'></image> </view> <view class='video-name'>{{item.title}}</view> <view class='video-desc' style="{{item.upStatus?'':'display:-webkit-box'}}">{{item.description}}</view> <view class='video-bottom'> <view class='video-btn' data-index="{{index}}" bindtap='upDown'> <image hidden='{{item.upStatus}}' src='/images/icon/slide.png'></image> <image hidden='{{!item.upStatus}}' src='/images/icon/up.png'></image> <text>{{!item.upStatus?'展开':'收起'}}</text> </view> </view> </view> </block>
js
videoPlay(event){ var index = video.getDataSet(event, 'index'); if (!this.data.videoIndex) { // 没有播放时播放视频 this.setData({ videoIndex: index }) var videoContext = wx.createVideoContext('video' + index) videoContext.play() } else { var videoContextPrev = wx.createVideoContext('video' + this.data.videoIndex) videoContextPrev.stop() this.setData({ videoIndex: index }) var videoContextCurrent = wx.createVideoContext('video' + index) videoContextCurrent.play() } },
在页面布局上,我们让视频的封面图定位在视频的容器中,将播放按钮定位到视频容器中,且层级最高。因为需求是点击封面图上的播放按钮视频开始播放,所以将show-center-play-btn设置为flase。在循环绑定数据时,将循环的index拼成视频的ID,将循环的index作为属性绑定到播放按钮。
在JS中,首先我们设置videoIndex来表示当前播放的视频在列表中的位置,它的初始值为null。
视频的播放与暂停
当点击事件发生时,首先获取点击的index,然后判断videoIndex的值:
- 如果videoIndex值为null,则表示这是第一次点击,将index绑定到videoIndex上,然后通过var videoContext = wx.createVideoContext('video' + index)来获取当前点击的视频,并使用videoContext.play()将视频进行播放。
- 如果videoIndex的值不为null,则表示这不是第一次点击,我们首先应该将正在播放的视频停止,然后在播放点击的视频。此时,videoIndex的值表示正在播放的视频在列表中的位置,我们通过var videoContextPrev = wx.createVideoContext('video' + this.data.videoIndex)来获取正在播放的视频上下文,然后通过videoContextPrev.stop()把它停止。最后我们将获取到的index值重新绑定到videoIndex上表示点击视频的序号,然后重复步骤一。
封面图处理
我们已经给封面图和封面图上的播放按钮进行处理了,用微信的wx:if或者hidden就可以了,当videoIndex等于index的时候,表示要播放这个视频,将视频显示并播放,封面图和播放按钮隐藏就可以了。
一点小坑
一开始考虑到性能,由于wx:if在页面加载的时候并不渲染数据,频繁点击的话频繁渲染数据,有点影响性能,就采用了hidden方法,使用hidden方法处理封面图和播放按钮一点问题也没有,处理视频的话有时候会出现视频不播放,并且显示中间播放按钮的情况,所以采用了wx:if,这样页面开始渲染的时候不渲染视频,点击之后渲染视频,并且设置视频自动播放,就可以啦~~~
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
内容总结
以上是互联网集市为您收集整理的小程序视频列表中视频的播放与停止的示例代码全部内容,希望文章能够帮你解决小程序视频列表中视频的播放与停止的示例代码所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。