uniapp video视频全屏播放后退出,页面字体变大,样式混乱问题

uniapp官方的说法是因为页面使用rpx,但是全屏和退出全屏自动计算屏幕尺寸不支持rpx,建议使用px。

但是因为uniapp端的开发都是使用rpx作为屏幕尺寸计算参数,不可能因为video全屏播放功能就整个全部修改,工作量大,耗时耗力。

所以就有了下面的解决方法。

我的方式是:通过创建空白页面过渡。

1.新建blank.vue页面:

javascript 复制代码
<template>
	<!-- 此空白页面用于处理视频全屏退出后页面样式混乱 -->
	<view>
	</view>
</template>

<script>
	export default {
		data() {
			return {}
		},
		methods: {},

		onLoad() {
			// #ifdef APP-PLUS
			plus.screen.unlockOrientation(); //解除屏幕方向的锁定,但是不一定是竖屏;
			plus.screen.lockOrientation('portrait'); //锁死屏幕方向为竖屏
			// #endif
			setTimeout(() => {
				uni.navigateBack({
					delta: 1
				})
			}, 30)
		},
	}
</script>

<style>

</style>

2.video标签监听全屏事件:

javascript 复制代码
<video id="videoId" ref="playVideo" :src="encodeURI(getVideo(resourceId))" controls autoplay
			@timeupdate="updateTime" @play="playToVideo" @fullscreenchange="screenChange">
		</video>
  1. method方法中监听退出全屏事件,如果退出,跳转上述空白页面。
javascript 复制代码
    methods: {
			screenChange(e) {
				//视频全屏退出后页面样式混乱,跳转空白页处理后再返回本页
				// #ifdef APP-PLUS
				if (!e.target.fullScreen) {
					uni.navigateTo({
						url: '/subpages/multimedia/blank',
						animationType: 'none',
						animationDuration: 0
					})
				}
				// #endif
			}
    }

4.在空白页面中切换为竖屏后再返回video所在页面。这时候rpx参数重新计算,不会污染页面样式。

5.效果:

相关推荐
2501_920931701 小时前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜
javascript·react native·react.js·游戏·ecmascript·harmonyos
layman05281 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔1 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李1 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN1 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒1 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局
PHP武器库1 小时前
ULUI:不止于按钮和菜单,一个专注于“业务组件”的纯 CSS 框架
前端·css
方也_arkling2 小时前
Element Plus主题色定制
javascript·sass
电商API_180079052472 小时前
第三方淘宝商品详情 API 全维度调用指南:从技术对接到生产落地
java·大数据·前端·数据库·人工智能·网络爬虫
晓晓莺歌2 小时前
vue3某一个路由切换,导致所有路由页面均变成空白页
前端·vue.js