位置: IT常识 - 正文

如何在uniapp中优雅地使用WebView(uniapp如何使用)

编辑:rootadmin
如何在uniapp中优雅地使用WebView 这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助从webview页面传值到uniapp中官方文档已经很详细了,这里给大家上我的实战代码,首先在webview页面中引入相关依赖:<!-- uniapp各平台依赖 --><script type="text/javascript"> var userAgent = navigator.userAgent; if (userAgent.indexOf('AlipayClient') > -1) { // 支付宝小程序的 JS-SDK 防止 404 需要动态加载,如果不需要兼容支付宝小程序,则无需引用此 JS 文件。 document.writeln('<script src="https://appx/web-view.min.js"' + '>' + '<' + '/' + 'script>'); } else if (/QQ/i.test(userAgent) && /miniProgram/i.test(userAgent)) { // QQ 小程序 document.write('<script type="text/javascript" src="https://qqq.gtimg.cn/miniprogram/webview_jssdk/qqjssdk-1.0.0.js"><\/script>'); } else if (/miniProgram/i.test(userAgent)) { // 微信小程序 JS-SDK 如果不需要兼容微信小程序,则无需引用此 JS 文件。 document.write('<script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.4.0.js"><\/script>'); } else if (/toutiaomicroapp/i.test(userAgent)) { // 字节跳动小程序 JS-SDK 如果不需要兼容字节跳动小程序,则无需引用此 JS 文件。 document.write('<script type="text/javascript" src="https://s3.pstatp.com/toutiao/tmajssdk/jssdk-1.0.1.js"><\/script>'); } else if (/swan/i.test(userAgent)) { // 百度小程序 JS-SDK 如果不需要兼容百度小程序,则无需引用此 JS 文件。 document.write('<script type="text/javascript" src="https://b.bdstatic.com/searchbox/icms/searchbox/js/swan-2.0.18.js"><\/script>'); }</script><!-- uni 的 SDK --><script type="text/javascript" src="https://js.cdn.aliyun.dcloud.net.cn/dev/uni-app/uni.webview.1.5.2.js"></script>然后通过uni.postMessage向uniapp传值: document.addEventListener('UniAppJSBridgeReady', function() { uni.postMessage({ data: { action: 'message' } }); uni.getEnv(function(res) { console.log('当前环境:' + JSON.stringify(res)); }); });在uniapp中监听message:<template lang="pug"> view web-view.webview(:src="url" @message="getMessage")</template><script> export default { data() { return { url: "https://zys201811.boringkiller.cn/shianonline/webview/vod.html?data=123", } }, methods: { getMessage(event) { let data = event.detail.data console.log(data); } } }</script><style lang="stylus" scoped>$webviewHeight = 420rpx.webview width 750rpx height $webviewHeight</style>从uniapp中动态传值到webview页面按照官方文档,从uniapp传值到webview中,只能通过query:<template lang="pug"> view <!-- #ifdef APP-PLUS --> web-view.webview(:src="url") <!-- #endif --></template><script> export default { data() { return { url: "https://zys201811.boringkiller.cn/shianonline/webview/vod.html?data=123", } } }</script><style lang="stylus" scoped>$webviewHeight = 420rpx.webview width 750rpx height $webviewHeight</style>在webview中解析query:let data = getQuery('data')console.log(data); // 获取 uni-app 传来的值// 取url中的参数值function getQuery(name) { // 正则:[找寻'&' + 'url参数名字' = '值' + '&']('&'可以不存在) let reg = new RegExp("(^|&)"+ name +"=([^&]*)(&|$)"); let r = window.location.search.substr(1).match(reg); console.log(r); if(r != null) { // 对参数值进行解码 return decodeURIComponent(r[2]); } return null;}但是,我发现,通过向web-view的src中传值,只能传一次,如果参数改变了,没法动态传到webview。对于这种需要动态传递参数的需求,我们可以使用动态创建webview达到目的,而不是通过webview组件。实现如下:<template lang="pug"> view</template><script> export default { data() { return { url: "https://zys201811.boringkiller.cn/shianonline/webview/vod.html", } }, mounted() { // #ifdef APP-PLUS var w = plus.webview.create(this.url + '?data=good'); w.show(); setTimeout(() => { plus.webview.close(w); setTimeout(() => { w = plus.webview.create(this.url + '?data=123'); w.show(); }, 1000) }, 1000) // #endif } }</script>以上,通过plus.webview.create创建一个webview,然后显示。如果数据更新了,可以先关闭之前的一个webview,然后重新创建一个,再显示。也可以直接使用open刷新页面:// #ifdef APP-PLUSvar w = plus.webview.open(this.url + '?data=good');setTimeout(() => { w = plus.webview.open(this.url + '?data=123');}, 1000)// #endif相关API:// 创建窗口WebviewObject plus.webview.create( url, id, styles, extras );// 创建并打开窗口WebviewObject plus.webview.open( url, id, styles, aniShow, duration, showedCB );// 显示窗口void plus.webview.show( id_wvobj, aniShow, duration, showedCB, extras );// 隐藏窗口void plus.webview.hide( id_wvobj, aniHide, duration, extras );// 关闭窗口void plus.webview.close( id_wvobj, aniClose, duration, extras );调用webview中的方法动态传值还有一种解决方案,就是通过evalJs方法直接调用webview中方法。具体实现如下:在模板中,通过ref暴露web-view元素:<template lang="pug"> web-view(:src="url" ref="wb")</template>在mounted生命周期的时候获取此元素:// #ifdef APP-PLUSthis.wb = this.$refs.wb// #endif在需要调用webview中方法的时候使用evalJs:// #ifdef APP-PLUSthis.wb.evalJs(`showAlert(${this.num})`)// #endif在webview页面定义对应的方法即可:function showAlert(num) { alert(num)}从uniapp动态传值,可以使用这种方式。注意:在nvue中,只有通过ref暴露webview节点才能拿到webview本身注意evalJs的拼写方式,官方文档是evalJS,但通过ref获取时,S应该为小写如果对您有所帮助,欢迎您点个关注,我会定时更新技术文档,大家一起讨论学习,一起进步。
本文链接地址:https://www.jiuchutong.com/zhishi/287282.html 转载请保留说明!

上一篇:vue 在for循环中设置ref并获取$refs(vue for循环遍历对象取值)

下一篇:最贵的域名是什么(最贵的域名是什么名字)

  • 报税扣款锁定如何解除
  • 非税收入未上缴
  • 企业所得税减免所得税额计算公式
  • 免税收入怎么做账务处理
  • 城建税计算方法有哪些
  • 公账的钱取现金
  • 医疗垃圾处理费标准2020
  • 收到工程服务费会计分录
  • 金融商品转让为什么不能扣除相关税费
  • 应发工资和实发工资计算公式excel
  • 租的厂房水电费开不了发票怎么办
  • 外贸企业一般纳税人申报
  • 临时聘用人员费用谁承担
  • 企业税收滞纳金需要纳税调整吗
  • 企业发给员工年终奖金
  • 生产企业电梯维修方案
  • 其他扣款税后应该怎么做账?
  • 没有增值税发票怎么出口
  • 小规模纳税人计提增值税账务处理
  • 某企业2016年年末经营资产总额为4000万元
  • 营改增后转让土地使用权怎么计算增值税
  • 有子公司一定要交社保吗
  • 机动车发票冲红怎么操作
  • 增值税发票自查报告
  • 有进项没有销项会计处理
  • 产值税收是什么意思
  • 设置按住键盘重启怎么弄
  • 如何使用腾讯手机管家
  • 应交增值税的结转
  • php zip模块
  • 收到违约金赔款计入什么科目
  • 存货盘盈怎么做账
  • 收到现金股利或债券利息时会计分录
  • php静态页面生成
  • vue.js in action
  • 基建账如何并入会计科目
  • 长期应付款核算范围有哪些
  • 商企预提待付的钱怎么办
  • node.js的安装步骤
  • vue知识点汇总
  • Github ChatGPT-Web:了解最新AI技术的前沿应用!
  • Yii2中DropDownList简单用法示例
  • vue2 自定义 el-radio-button 的样式并设置默认值的方法
  • 发票认证的目的和意义
  • 在阿里云的云主机之间怎么通信
  • 其他收益在利润表中的位置
  • 税费退库怎么做账
  • 哪些企业可以不计提盈余公积
  • 汽油发票怎么开专票
  • 增值税专用发票几个点
  • 公司买车可以少多少钱
  • 土地无形资产摊销的会计处理方法
  • 发工资扣的个人社保计入哪个科目
  • 固定资产清理账务处理流程
  • 资产负债表里的应交税费怎么填
  • 可以从公司公户直接支付给个人的款项有哪些
  • 公司变更地址后需要做哪些事情
  • mysql绿色版和安装版有什么区别
  • 关闭默认共享的影响
  • Windows Server 2008下 驾驭拨号上网
  • soffice.exe - soffice进程是什么意思 有什么用
  • info.exe是什么病毒
  • win10提醒功能
  • 完美解决gvim的菜单乱码问题
  • 批处理执行另一个批处理
  • android开发范例实战宝典
  • 生成ssh
  • unity加密代码
  • php守护进程的应用场景
  • 简洁实用的公司治理机制
  • javascript函数怎么写
  • php使用js
  • 求行驶时间的公式
  • js图片预览
  • 河南税务公众号缴费养老保险
  • 北京朝阳地税局电话号码
  • 外购的解释
  • 常州税务局举报网站
  • 交完车船税后地税局都给什么
  • 单位轿车出售怎么处理
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设