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

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

  • a14和a12z哪个性能好(a14和a12z谁强)

    a14和a12z哪个性能好(a14和a12z谁强)

  • 红米k20发热正常吗(红米k20pro发烫)

    红米k20发热正常吗(红米k20pro发烫)

  • 抖音钻石卡怎么获取(抖音钻卡是内定的吗)

    抖音钻石卡怎么获取(抖音钻卡是内定的吗)

  • 值传递和地址传递的区别(值传递和地址传递的方式)

    值传递和地址传递的区别(值传递和地址传递的方式)

  • 微信怎么在聊天界面顶端加文字(微信怎么在聊天记录查找表情包)

    微信怎么在聊天界面顶端加文字(微信怎么在聊天记录查找表情包)

  • 打印机打一张停顿一下(打印机打一张停好久,才会打下一张)

    打印机打一张停顿一下(打印机打一张停好久,才会打下一张)

  • 快手刷粉会有什么影响吗

    快手刷粉会有什么影响吗

  • 手机无缘无故没信号(手机无缘无故没信号重启都没用)

    手机无缘无故没信号(手机无缘无故没信号重启都没用)

  • 手机QQ为什么换手机登录不了(手机QQ为什么换不了头像)

    手机QQ为什么换手机登录不了(手机QQ为什么换不了头像)

  • oppohd模式是什么意思(oppohd模式有什么用)

    oppohd模式是什么意思(oppohd模式有什么用)

  • oppo手表41mm和46mm的区别是什么(oppo手表41毫米)

    oppo手表41mm和46mm的区别是什么(oppo手表41毫米)

  • 华为原装屏幕和非原装区别(华为原装屏幕和特惠屏)

    华为原装屏幕和非原装区别(华为原装屏幕和特惠屏)

  • subwoofer是什么接口(subwoofer是什么意思中文)

    subwoofer是什么接口(subwoofer是什么意思中文)

  • qq群怎么删除聊天记录让别人也看不到(qq群聊怎么删掉)

    qq群怎么删除聊天记录让别人也看不到(qq群聊怎么删掉)

  • 小米8青春版支持18w吗(小米8青春版支持多少w快充)

    小米8青春版支持18w吗(小米8青春版支持多少w快充)

  • 电信手机号积分有什么用(电信手机号积分换话费怎么换)

    电信手机号积分有什么用(电信手机号积分换话费怎么换)

  • 小米mix3触屏校准(小米mix3屏幕不灵敏如何调试)

    小米mix3触屏校准(小米mix3屏幕不灵敏如何调试)

  • 微信扫码黑屏怎么回事(微信扫码黑屏怎么办解决)

    微信扫码黑屏怎么回事(微信扫码黑屏怎么办解决)

  • 结构化程序设计缺点(结构化程序设计方法)

    结构化程序设计缺点(结构化程序设计方法)

  • 爱奇艺手机号解除注销(爱奇艺手机号解绑多久可以绑定其他账号)

    爱奇艺手机号解除注销(爱奇艺手机号解绑多久可以绑定其他账号)

  • 车旺大卡怎么分享给别人(车旺大卡怎么分享永久怎么取消)

    车旺大卡怎么分享给别人(车旺大卡怎么分享永久怎么取消)

  • iwatch接收微信无提醒(iwatch怎么接收微信)

    iwatch接收微信无提醒(iwatch怎么接收微信)

  • iphonexr电池多大(iphonexr电池最大容量多少该换)

    iphonexr电池多大(iphonexr电池最大容量多少该换)

  • 如何设置手机时间显示(如何设置手机时间精确到秒)

    如何设置手机时间显示(如何设置手机时间精确到秒)

  • 施工企业的临时设施,属于企业的固定资产
  • 印花税是什么时候交的钱
  • 个体工商户需要交税吗?怎么交?
  • 移动发票抬头个人税号公司能报销吗
  • 某项目全部投资资金的40%由银行贷款
  • 个人所得税经营所得申报
  • 境内企业向境外放款额度最长放款期限为两年
  • 政策信息咨询服务要到哪个部门办理资质
  • 事业单位劳务派遣工作值得去吗
  • 应付账款不用付了摘要怎么写
  • 预计负债收回的会计分录
  • 商贸公司账目
  • 企业购买劳保用品会计处理
  • 对方跨行转账成功后我却没收到款还能追回来吗
  • 购买税控设备,享受何种优惠政策
  • 当月认证的发票可以当月抵扣吗
  • 学校里的水电费是政府买单吗
  • 交防伪税控技术怎么交
  • 预付油卡怎么入账
  • 以前年度损益调整怎么用
  • 19年入职19年离职
  • 企业发放贷款怎么做分录
  • 个人出租车辆给公司个人所得税
  • 资产负债率如何评价
  • 企业合并案例
  • 坏账损失的确定原则
  • 处理车辆违章送什么证件
  • 工程材料怎么开票
  • 对公账户收款
  • easyexcel解析csv
  • php imagettftext
  • 最小的手机有多大
  • PHP:imagecolordeallocate()的用法_GD库图像处理函数
  • php编程计算日期怎么算
  • yolov5标签格式
  • 接受母公司捐赠无协议约定
  • 三联专用发票每一联分别给谁
  • uniapp简介
  • 浅谈php中静态方法的应用
  • phpcms v9用户手册
  • 股东转让股份会退股吗
  • 递延所得税资产怎么计算
  • 汇总纳税企业所得税征收管理办法
  • 收到快递赔款分录怎么做
  • 职工教育经费年底要冲回吗
  • 上传附件不成功怎么回事
  • 链表的优缺点有哪些
  • 增值税发票红字发票未抵扣怎么开
  • 开票信息修改
  • 获取sqlsession
  • mssqlserver数据能删吗
  • 开票内容不在经营范围内
  • 先付款后签协议是否违法
  • 误餐补助需要提供发票吗
  • 土地出让金如何缴纳
  • 公司股权变更如何合理避税
  • 金税三期升级功能2020
  • 补发工资怎么补发
  • 领用包装物的会计处理
  • 类似wps office的手机软件
  • Win2000/2003 Broadcom 网卡 teaming 配置手册
  • redhat操作系统安装步骤
  • 提升xp系统流畅度
  • win7桌面图标变成了lnk
  • 如何设置windows桌面图标
  • win10系统怎样卸载程序
  • 车钥匙失灵了10秒教你快速解决
  • linux的shm共享内存
  • css教程实例
  • cocos2d
  • android native opengl
  • vue自定义方法
  • unity 3d ui
  • unity获取当前位置
  • unityc#脚本
  • 在xml文件里使用的命令
  • JavaScript Try...Catch 声明的 使用方法
  • 小规模纳税人开1%普票怎么报税
  • 无锡税务局领导
  • 怎样通过发票号码查询电子发票
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设