【工作实践-06】uniapp使用webView

一、建立APP页面和webview的通讯

1.引入webview.js

App 端使用 uni.web-view.js 的最低版为 uni.webview.1.5.4.js

APP端可以支持网络网页和本地网页,但如果使用本地网页和相关资源(js、css等文件)必须放在**static**目录下。

2.引入搭桥document.addEventListener('UniAppJSBridgeReady',function(){})

在app端是识别不到document元素的,所以为了适配app,需要将搭桥的方法单独建立一个js文件放到**static**目录下

javascript 复制代码
document.addEventListener('UniAppJSBridgeReady', function () {
	console.log('我建立起了通讯');
	uni.postMessage({
		data: {
			successFlag: true,
		}
	});
})

3.发送消息

首先<web-view>中需要添加message的监听,当网页向应用 postMessage 时,会在特定时机(后退、组件销毁、分享)触发并收到消息。

html 复制代码
<web-view ref="webview" :src="webViewUrl" @message="onPostMessage"></web-view>

其次网页向应用 postMessage 需要通过 wv.evalJS(``)方法,在此方法中利用uniapp的postMessage()方法向应用发送消息

javascript 复制代码
wv.evalJS(`uni.postMessage({
					data: {
					  base64: canvas.toDataURL("image/png"),
					}
				});	`)

最后在uniapp通过 onPostMessage 函数中获取网页信息

javascript 复制代码
onPostMessage: function (e) {
				console.log(e.detail.data[0])
			},

二、webview初始化遇坑

1.setJsFile() 和 appendJsFile() 方法的区别

在初始化webview时,需要引入webview.js文件和添加的搭桥 js (post.js)文件

此时需注意 setJsFile() 和 appendJsFile() 方法的区别:

setJsFile :设置新的JS文件后将清空之前设置的值。也就是后台如果一直 setJsFile,那么只有最后一个js文件生效。

appendJsFile:添加多个js文件将按照添加的先后顺序执行。

2. 文件路径

setJsFile() 和 appendJsFile()方法中所写的文件路径一定要正确

如果文件路径从static目录开始写,比如这样:

javascript 复制代码
wv.setJsFile("static/uni.webview.1.5.5.js")
wv.appendJsFile("static/post.js")

这样写在安卓端没有问题,运行很顺利,但是在 IOS 端就会发现这两个方法所加文件并未生效,所以文件路径一定要写正确,默认带上'_www'****,

javascript 复制代码
wv.setJsFile("_www/static/uni.webview.1.5.5.js")
wv.appendJsFile("_www/static/post.js")

3. setJsFile() 和 appendJsFile()方法所写时机

在渲染时写 setJsFile() 和 appendJsFile()方法,在安卓端不会有任何问题,但在IOS端会发现这两个方法并未生效

因此建议在 IOS 端 setJsFile() 和 appendJsFile() 操作应放在监听 loaded 事件之后

javascript 复制代码
            var currentWebview = this.$scope.$getAppWebview() //此对象相当于html5plus里的plus.webview.currentWebview()。在uni-app里vue页面直接使用plus.webview.currentWebview()无效
			this.wv = currentWebview.children()[0]

			this.wv.addEventListener("loaded", () => {
			    this.wv.setJsFile("_www/static/uni.webview.1.5.5.js")
			    this.wv.appendJsFile("_www/static/post.js")
			    console.log('加载完成');
			    this.getImg() // 加载完成后获取一次验证码图片,但可能获取为空
			}, false);
			

4.setStyle()设置样式只能在APP端生效

只有app可以设置webview的宽高,其他的端是无解的

利用节点信息减去其他内容的高度,得到webview的高度,this.scope.scope.scope.getAppWebview()获取webview实例(只能app使用),再修改实例setStyle设置。

5.层级问题(事件不触发)

在uniapp使用webview时,需要注意样式层级问题,如下代码,若在当前页面使用了webview,则点击时不会触发点击事件,原因就是webview显示层级高于当前页面

解决:添加样式层级:z-index: 999;

html 复制代码
        <view class="privacy">
				<view @click="toPrivacy('user')"><u--text text="机电用户协议" size="12"></u--text></view>、
				<view @click="toPrivacy('privacy')"><u--text text="隐私协议" size="12"></u--text></view>
		</view>
相关推荐
哆啦A梦15882 小时前
[前台小程序] 01 项目初始化
前端·vue.js·uni-app
2501_915918415 小时前
HTTPS 端口号详解 443 端口作用、iOS 抓包方法、常见 HTTPS 抓包工具与网络调试实践
android·网络·ios·小程序·https·uni-app·iphone
2501_9151063214 小时前
App Store 软件上架全流程详解,iOS 应用发布步骤、uni-app 打包上传与审核要点完整指南
android·ios·小程序·https·uni-app·iphone·webview
快起来搬砖了14 小时前
实现一个优雅的城市选择器组件 - Uniapp实战
开发语言·javascript·uni-app
数学分析分析什么?15 小时前
Uniapp中使用renderjs实现OpenLayers+天地图的展示与操作
uni-app·openlayers·天地图·renderjs
海绵宝宝不喜欢侬15 小时前
UniApp微信小程序-实现蓝牙功能
微信小程序·uni-app
Python大数据分析17 小时前
uniapp微信小程序商品列表数据分页+本地缓存+下拉刷新+图片懒加载
缓存·微信小程序·uni-app
机构师17 小时前
<uniapp><指针组件>基于uniapp,编写一个自定义箭头指针组件
javascript·uni-app·vue·html
小白_ysf17 小时前
uniapp和vue3项目中引入echarts 、lime-echart(微信小程序、H5等)
微信小程序·uni-app·echarts·h5·lime-echart
imHere·17 小时前
UniApp 分包异步化配置及组件引用解决方案
微信小程序·uni-app·分包