uniappvideo避坑指南(H5、小程序、app)

news2025/1/19 14:28:15

今天写下这篇文章已是蓄谋已久了,背景是年初接到项目需求开发基于H5运行的视频学习平台,以及后来uniapp转小程序app开发。相信开发过uniapp的video应该或多或少都遇到过一些坑,开场就不多说了,直接上干货。

项目要求用户不得拖动进度条,由播放进度触发对应事件


首先说说uniappH5使用video

H5是基于浏览器运行,那么浏览器平台就是我们需要考虑的兼容问题,就像我们之前写pc端的时候对IE的多年奋战一样,给大家列举一下现在市上使用率比较高的浏览器平台

QQ浏览器=>360浏览器=>UC浏览器=>谷歌浏览器(这个如果不是开发者应该使用率不多)等等

 就拿我们常见使用的浏览器举例把:

QQ、UC、360浏览器等常见平台都会在渲染video标签时劫持播放器,渲染内置可脱离网页进行播放,严重与项目需求不符,无论用何种方法都绕不开,

百度浏览器目前未发现劫持事件,但是运行百度时切入后台,过一段时间在切回浏览器项目是会白屏浏览器bug,无法绕开

开发H5如果需要背景和我一样的要注意及时和经理商量商量了

其次在说说app

各位开发者应该都知道video层级的问题,既然我们的需求是不然用户拖动进度条,那么就得考虑如何实现,我的思路是覆盖元素dom遮罩层,自己写播放控件,cover-view、cover-image是我们所需的救星,官方简介部分组件如map、video、textarea、canvas通过原生控件实现,原生组件层级高于前端组件(类似flash层级高于div)。为了能正常覆盖原生组件,设计了cover-view。

发现了光,但是开发一般发现video在全屏时cover-view不生效了,翻阅文档原理是app.vue页面video全屏不支持,得采用元素nvue页面写法

video全屏后,如何自行绘制界面?比如加个标题、加个分享按钮

app端 2.1.5 以上nvue页面的video也可以通过cover-view来绘制界面覆盖元素

继续我们的开发过程,完成在app端覆盖自定义播放组件,新的问题出现了,获取播放进度

@timeupdate="onTimeupdate"官方播放进度变化事件通过e.detail.currentTime获取进度赋值给initial-time达到保存进度,进入页面跳转到上传播放位置,但是发现nvue设置完毕后卡顿,timeupdate发现官方介绍说触发频率是250毫秒一次 ,且initial-time是实时推进的,打个比方timeupdate获取到的时间是4秒出发4次之后才是5秒,等于initial-time会被赋值4次,难,想办法,定义2个变量,一个进入页面赋值initial-time跳转到对应位置,一个通过timeupdate获取当前比方时间,ok了,

播放下一个视频时问题又来了,initial-time直接去上一个视频的e.detail.currentTime播放时间直接跳转了,需求无法完成,换思路,还是改用.vue页面的方式写吧,起码e.detail.currentTime是正常的,那我们全屏的时候怎么办呢,videoContext.seek()跳转到指定播放位置,采用timeupdate事件监听播放进度变化,超过3秒就不是正常播放,为用户手动拖拽进度条

this.videoTime = parseInt(e.detail.duration)
if((currenttime - this.curCourse.Progress > 3 || currenttime - this.curCourse.Progress <     
   -1) && this.plan.FinishedExam!== 1 && this.plan.FinishedCourses !== 1){
	this.videoContext.seek(this.curCourse.Progress)
}else{
	this.videoRealTime = currenttime
	if(this.videoRealTime > this.curCourse.Progress){
		this.curCourse.Progress = this.videoRealTime
	}
}

这个大家应该能看懂把,变量在data中自行定义

实现效果达到预期,不足的是用户拖拽进度条,在使用seek()拖回来时video会触发@waiting事件加载,视频会卡顿一下。

打包交给测试,测试反馈播放视频会不定期闪退,我懵逼了。这怎么搞,没遇到过啊

开始因为是测试的手机太垃圾,死鸭子说你手机不行换手机测测,测试哄骗公司大大小小5,6个小姐姐的手机在测,现象一样,都是播放视频不定期会闪退。

怎么办,解决呀。代码没问题呀,初步闪退为内存消耗搞导致的,面向百度把

https://ask.dcloud.net.cn/question/117091

https://ask.dcloud.net.cn/question/66095

video高阶组件重新按照官方进行修改,发现怎么都不管用,

后来一直沿着这个思路百度优化,终于找到这篇文章,可以运行动态查看当前手机内存情况各位有时间组件研究一下把,问题找到了,但是解决方案?没有!!!

根本没有任何一篇文章说相似我的bug,只能自己摸索了。

距离测试反馈的闪退bug已经4天了,依然没有解决,emo了!!!

中间有想过是不是视频地址的编码问题或者是https等等,一一pas

就在刚刚突然想到nvue页面开发是基于原生渲染的性能更好,说干就干,开整

实际与预期一至,个人见解是nvue有更好的性能处理不vue页面更快,但是nvue缺点也是无奈,各位只能自己去摸索了,但是刚刚我们提到的e.detail.currentTime应该怎么办呢,个人解决方案 放弃initial-time调用保存的播放进度 在play事件里利用seek方法给拉过去

onplay(e){																						    
    //当开始/继续播放时触发play事件,这里的clStatus 是我自己定义的播放开始还是暂停的标识
	console.log(this.clStatus,'onplay')
	if(this.clStatus === 2){
	this.videoContext.seek(this.curCourse.Progress)
	this.clStatus = 1
	this.videoContext.play()
}

到此bug优化完成,其实video里面还是有很多坑。这里我就不一样解释了 ,如果大家有一些见解欢迎和我一起探讨,后期个人一会去话一些时间去写一个可以自定义进度条的video播放器,我相信很多项目是有这样的需求的。但是uniapp插件目前还没有这方面的实例

创作不易,转载请注明出处谢谢

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/408955.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

vue3引入router

1.添加vue-router依赖 进入项目路径的cmd下&#xff0c;执行命令 npm install vue-router4 或者yarn add vue-router4 推荐使用yarn命令&#xff0c;比npm安装更快 2.执行npm install重新加载依赖 3.在src文件夹下创建一个router文件夹 4.在router文件夹下创建index.js文件&…

JavaScript核心技术之JSON详解

JSON是什么&#xff1f; JSON&#xff08;JavaScript Object Notation, JS对象简谱&#xff09;是一种轻量级的数据交换格式。它基于 ECMAScript&#xff08;European Computer Manufacturers Association, 欧洲计算机协会制定的js规范&#xff09;的一个子集&#xff0c;采用…

undetected_chromedriver的使用

undetected_chromedriver是专门针对浏览器识别做出来的拓展 直接使用undetected_chromedriver第三方库 if __name__ __main__:from selenium import webdriverfrom selenium.webdriver.common.by import Byfrom selenium.webdriver.support.ui import WebDriverWaitfrom sel…

前端数据加密的几种方式

1.base64加密方式 1.1 base64是什么&#xff1f; Base64&#xff0c;顾名思义&#xff0c;就是包括小写字母a-z、大写字母A-Z、数字0-9、符号""、"/"一共64个字符的字符集&#xff0c;&#xff08;另加一个“”&#xff0c;实际是65个字符&#xff0c;至…

Access-Control-Allow-Origin跨域解决及详细介绍

首先&#xff0c;跨域不是问题。是一种安全机制。 这是你在开发时、上线前就必须提前考虑到的安全问题并且采取合适的手段去避免这个问题带来的程序错误。不过通常情况下&#xff0c;前端开发的小伙伴们都非常坚信后端小伙伴的接口一定已经处理好了跨域这个需求。然而事实上许多…

JavaWeb 项目 --- 表白墙 和 在线相册

文章目录一. 案例: 表白墙 (使用模板引擎)1. 首先创建 maven 项目2. 创建好模板文件3. 使用数据库存储数据.创建一个类用于数据库连接4. 使用 监视器 来初始化 Thymeleaf5. 编写 Servlet 代码① 重写 doGet 方法② 重写 doPost 方法③ 实现 load 方法④ 实现 save 方法6. 注意事…

Vue中key的作用及原理

1. 先说结论 key在Vue是DOM对象的标识&#xff1b;进行列表展示时&#xff0c;默认key是index&#xff1b;如果数据只做展示使用&#xff0c;使用index作为key是没有任何问题的&#xff1b;如果使用index作为key&#xff0c;而后续操作会破坏顺序&#xff0c;一定会带来效率问…

vue3 antd table表格样式修改——使用rowClassName更改某行数据的样式

vue3 antd项目实战——修改ant design vue组件中table表格的默认样式&#xff08;二&#xff09;知识调用场景复现修改table表格的行样式一、rowClassName添加行样式二、表格的不可控操作写在最后知识调用 文章中可能会用到的知识链接vue3ant design vuets实战【ant-design-vu…

解决:在 VSCode 中如何设置默认的浏览器为Chrome或Firefox

1、问题描述&#xff1a; 在 VSCode 编辑器中&#xff0c;其一般默认打开的浏览器是 IE 浏览器&#xff0c;而我已经习惯使用 Chrome 浏览器&#xff0c;以及会遇到页面的调试等不同的问题&#xff0c;因此需要将 VSCode 的默认浏览器调整为 Chrome 浏览器&#xff1b; 2、操…

【web前端开发】超详细讲解CSS盒子模型

文章目录1.盒子模型介绍2.内容3.边框4.内边距5.⭐盒子大小计算6.⭐内减模式7.外边距外边距的合并外边距的塌陷行内元素的垂直外边距8.⭐清除默认样式9.⭐版心居中1.盒子模型介绍 所有HTML元素可以看作盒子,CSS盒模型本质上是一个盒子&#xff0c;封装周围的HTML元素&#xff0c…

使用Vue来完成项目中的首页导航+左侧菜单

目录 1. 准备工作 2. 动态树 2.1 在配置请求路径 2.2 使用动态数据构建导航菜单 2.2.1 通过接口获取数据 2.2.3 通过后台获取的数据构建菜单导航 2.3 点击菜单实现路由跳转 2.3.1 创建书本管理组件 2.3.2 配置路由 2.3.3 修改LeftAside组件 2.3.4 修改Main组件 3. …

8个不能错过的程序员必备网站,惊艳到我了!!!

程序员是一个需要不断学习的职业&#xff0c;不少朋友每天来逛CSDN、掘金等网站&#xff0c;但一直都抱着“收藏从未停止&#xff0c;学习从未开始”的态度&#xff0c;别骗自己了兄弟。在编程体系中&#xff0c;有很多不错的小工具&#xff0c;可以极大得提升我们的开发效率。…

前端技术:解决执行npm install提示 xxx packages are looking for funding run `npm fund` for details的问题 详述npm fund

目录复现问题分析问题npm fund的命令npm fund的由来npm fund与npm ls解决问题参看文献&#x1f610; 我的博客&#xff0c;不仅帮你解决此类问题&#xff0c;还会告诉如何去分析定位问题。 复现问题 今天执行如下命令时&#xff1a; npm install报出如下问题&#xff1a; 2…

cookie、localStorage和sessionStorage详解

目录 一、cookie 二、Web storage 1、localStorage 2、sessionStorage的使用 3、复杂数据类型储存 Web Storage带来的好处&#xff1a; 三、sessionStorage、localStorage和cookie的区别 一、cookie cookie是客户端与服务器端进行会话使用的一个能够在浏览器本地化存储…

vue引入elementUi后打开页面报错Uncaught TypeError: Cannot read properties of undefined(reading ‘prototype‘)

vue引入elementUi后打开页面报错 本人在用idea创建vue项目并引入elemenUi之后网页报错&#xff1a; Uncaught TypeError: Cannot read properties of undefined(reading ‘prototype’)。 百度了很多办法都说是因为在vue3中引入了elementUi&#xff0c;vue3.0之后是不支持el…

基于Java+Springmvc+vue+element员工信息管理系统详细设计

博主介绍&#xff1a;✌公司项目主程、全网粉丝10W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,CSDN博客之星TOP100、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业设计✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f345;…

React中实现插槽效果的方案

文章目录React实现插槽children实现插槽props实现插槽React实现插槽 在开发中&#xff0c;我们抽取了一个组件&#xff0c;但是为了让这个组件具备更强的通用性&#xff0c;我们不能将组件中的内容限制为固定的div、span等等这些元素。 我们应该让使用者可以决定某一块区域到…

项目部署,一点也不难!

目录 一、部署前准备 &#xff08;一&#xff09;前端多环境准备 &#xff08;二&#xff09;后端多环境准备 二、项目部署 &#xff08;一&#xff09;原始部署 1、前端部署 2、前端部署测试 3、后端部署 &#xff08;二&#xff09;宝塔 Linux 部署 1、前端部署 2…

前端面试八股文--Vue篇(持续更新)

一. Vue2 篇 1.MVC MVVM区别 首先呢这是两种模式 MVC指的是 modal&#xff0c;view&#xff0c; controller MVVM 指的是 modal &#xff0c;view&#xff0c; view modal mvc和mvvm区别是&#xff1a;1、处理业务的模式不同&#xff0c;MVC里&#xff0c;View是可以直接访…

在 Vue3 中使用 Vuex

本篇文章主要记录 Vue3 中使用 Vuex 的步骤和注意事项&#xff1a; 1、安装依赖库 npm install vuex --save-dev2、配置 Vuex 实例 对比 Vue2 和 Vue3 各自创建 Store 实例的区别&#xff1b; Vue2 是用 Vue.use(Vuex)注入 Vuex 插件&#xff0c;然后通过 new Vuex.Store(o…