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
目录下
document.addEventListener('UniAppJSBridgeReady', function () { console.log('我建立起了通讯'); uni.postMessage({ data: { successFlag: true, } }); })
3.发送消息
首先<web-view>中需要添加message的监听,当网页向应用 postMessage
时,会在特定时机(后退、组件销毁、分享)触发并收到消息。
<web-view ref="webview" :src="webViewUrl" @message="onPostMessage"></web-view>
其次网页向应用 postMessage 需要通过 wv.evalJS(``)方法,在此方法中利用uniapp的postMessage()方法向应用发送消息
wv.evalJS(`uni.postMessage({ data: { base64: canvas.toDataURL("image/png"), } }); `)
最后在uniapp通过 onPostMessage 函数中获取网页信息
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目录开始写,比如这样:
wv.setJsFile("static/uni.webview.1.5.5.js") wv.appendJsFile("static/post.js")
这样写在安卓端没有问题,运行很顺利,但是在 IOS 端就会发现这两个方法所加文件并未生效,所以文件路径一定要写正确,默认带上'_www',
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 事件之后
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;
<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>
附:uniapp使用webview不占全屏
在uniapp中使用webview时,如果不希望webview占据全屏,可以通过以下方式进行设置。
在uniapp的页面中,可以使用flex布局来控制webview所占的比例。设置一个容器div,并给其设置宽度、高度及display属性为flex。然后将webview放置在这个容器中,可以通过设置容器的flex属性来控制webview的占比。
另一种方式是使用css样式来控制webview的宽高以及位置。在uniapp页面的style标签中,可以给webview设置具体的宽度、高度以及margin、padding属性来调整其位置和大小。
通过以上两种方式,可以调整webview的尺寸,使其不占满整个屏幕。可以根据实际需要,灵活运用这些方法,来适配不同的页面布局需求。
需要注意的是,uniapp中的webview组件在不同平台上的表现可能会有所不同,因此还需要根据目标平台进行适当的调整。
总结
到此这篇关于uniapp使用webView的文章就介绍到这了,更多相关uniapp使用webView内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!