位置: 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循环遍历对象取值)

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

  • excel怎么删除空白多余格子(excel怎么删除空白格而不删除整行)

    excel怎么删除空白多余格子(excel怎么删除空白格而不删除整行)

  • iPhoneXR系统无法更新怎么办(iphonexr系统更新不了)

    iPhoneXR系统无法更新怎么办(iphonexr系统更新不了)

  • 每个人只能集一个五福吗(每个人只能集一套五福吗)

    每个人只能集一个五福吗(每个人只能集一套五福吗)

  • i7蓝牙耳机怎么充电(i7蓝牙耳机怎么看电量)

    i7蓝牙耳机怎么充电(i7蓝牙耳机怎么看电量)

  • 手机欠费变成空号了对自己有影响吗(手机欠费变成空号)

    手机欠费变成空号了对自己有影响吗(手机欠费变成空号)

  • 华为荣耀8x录屏功能在哪(华为荣耀8x录屏怎么录制系统声音)

    华为荣耀8x录屏功能在哪(华为荣耀8x录屏怎么录制系统声音)

  • qq文件怎么设置永久(qq文件怎么设置永久有效)

    qq文件怎么设置永久(qq文件怎么设置永久有效)

  • 电脑可以直接连wifi吗(电脑可以直接连网线接口吗)

    电脑可以直接连wifi吗(电脑可以直接连网线接口吗)

  • 华为gt2尊享版和运动版区别(华为gt2尊享版和运动版哪个好)

    华为gt2尊享版和运动版区别(华为gt2尊享版和运动版哪个好)

  • 华为平板显示充电但充不进去(华为平板显示充电但是充不进去怎么回事)

    华为平板显示充电但充不进去(华为平板显示充电但是充不进去怎么回事)

  • cadbak文件是什么(cad.bak文件)

    cadbak文件是什么(cad.bak文件)

  • 192.168.1.1为什么进不去(192.168.1.1为什么登不上)

    192.168.1.1为什么进不去(192.168.1.1为什么登不上)

  • 微信频繁打招呼封多久(微信频繁打招呼被限制怎么申诉)

    微信频繁打招呼封多久(微信频繁打招呼被限制怎么申诉)

  • 苹果手机开不了机充电没反应怎么办(苹果手机开不了无线网怎么回事)

    苹果手机开不了机充电没反应怎么办(苹果手机开不了无线网怎么回事)

  • 手机卡实名认证的不是本人的咋办(手机卡实名认证可以在手机上弄吗)

    手机卡实名认证的不是本人的咋办(手机卡实名认证可以在手机上弄吗)

  • 手机自录视频功能在哪(手机自录视频功能在哪华为)

    手机自录视频功能在哪(手机自录视频功能在哪华为)

  • oppoa3要怎么样关闭hd2(oppo手机如何关机)

    oppoa3要怎么样关闭hd2(oppo手机如何关机)

  • s10是双卡双待嘛(s10双卡还是单卡)

    s10是双卡双待嘛(s10双卡还是单卡)

  • 网课要过期了怎么下载(网课要过期了怎么保存作业帮)

    网课要过期了怎么下载(网课要过期了怎么保存作业帮)

  • ps全称英文怎么说(ps全称英文为)

    ps全称英文怎么说(ps全称英文为)

  • 快手能隐藏评论吗(快手隐藏评论怎么显示出来)

    快手能隐藏评论吗(快手隐藏评论怎么显示出来)

  • p语言是python吗(py语言属于)

    p语言是python吗(py语言属于)

  • buffalo路由器设置方法(buffalo wcr-gn路由器设置)

    buffalo路由器设置方法(buffalo wcr-gn路由器设置)

  • 钉钉如何打卡(钉钉如何打卡上班)

    钉钉如何打卡(钉钉如何打卡上班)

  • shwiconem.exe - shwiconem是什么进程 有什么用

    shwiconem.exe - shwiconem是什么进程 有什么用

  • Linux内核学习笔记——页表的那些事。(《linux内核分析》)

    Linux内核学习笔记——页表的那些事。(《linux内核分析》)

  • 2023小规模纳税人所得税税收优惠政策
  • 增值税专用发票电子版
  • 开诊所会计如何做账
  • 公司收到待报解预算收入会计分录
  • 盈余公积的作用与意义
  • 印花税不用计提会计第几号准则
  • 单位之间调动
  • 车船税每年都要交吗标准多少
  • 净资本和净资产区别
  • 二手房屋增值税税率
  • 银行汇兑怎么做账
  • 收到红字发票会计处理
  • 业务招待费进项税额需要转出吗
  • 软件开发的服务内容方式要求
  • 报税没有申报现金流量表
  • 资产原值包含残值吗
  • 支付车辆保险费及车船税会计科目
  • 购买法下购买成本包括
  • 个人出租住房如何倒算开票金额
  • 车间低值易耗品有哪些
  • swstrtr.exe - swstrtr是什么进程
  • 鸿蒙系统怎么同步数据
  • 房地产企业使用什么准则
  • 王者荣耀中张飞的台词
  • outpost.exe - outpost是什么进程 有什么用
  • 水养绿萝怎么养护长得才茂盛
  • 销售多余材料计入什么
  • 企业最佳资金结构
  • 委托贷款账务处理
  • php随机ua
  • vue.js前端开发快速入门与专业应用
  • 进项已认证后冲红又重开
  • 外经交的个税如何计算
  • 工会经费计入什么费用明细科目
  • uni-app实例教程
  • framework在哪里打开
  • 销售不同商品的会计分录
  • 微服务网关作用
  • python如何在一个文件中运行另一个文件
  • 医疗机构收据
  • 购买一台电脑2400元贵吗
  • 长期待摊费用的摊销方法
  • db2比较大小
  • 金税四期注意什么
  • 纳税人可以享受六项专项附加扣除
  • 金税盘技术服务费怎么交费
  • 分配人工费的会计分录
  • 企业收到的政府部门工作经费
  • 服装租赁费的税率是多少
  • 政府补助收入总额法会计分录
  • 影视公司临时演员怎么办
  • 百旺开发票清单
  • 邮寄发票的快递费走什么科目
  • 销售折让如何核算
  • 个税申报工资比实发工资高
  • win7访问共享文件
  • Win10桌面图标怎么隐藏
  • linux校验文件
  • 微软强制升级
  • linux如何给网卡配置ip地址
  • window10升级不了
  • /proc目录造成linux根目录爆满
  • win8.1系统补丁
  • javascript教程
  • 将list转换为json字符串
  • cssdeck
  • jquery炫酷效果
  • css中文字垂直排列
  • app录音功能开发
  • cmd开机启动命令
  • Python 中urls.py:URL dispatcher(路由配置文件)详解
  • 如何给textarea赋值
  • Python通过DOM和SAX方式解析XML的应用实例分享
  • 使用node
  • 安卓开源好处
  • js会话
  • 江西省发票综合服务平台
  • 河南车船税缴纳查询网
  • 建筑施工税务处理
  • 北京朝阳区地税服务大厅
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设