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

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

  • 产品经理如何写好一份年终总结(产品经理如何写简历)

    产品经理如何写好一份年终总结(产品经理如何写简历)

  • 红米k30pro刷新率是多少(红米k30Pro刷新率)

    红米k30pro刷新率是多少(红米k30Pro刷新率)

  • 苹果11pro max微信怎么加密(苹果11promax微信来消息没声音)

    苹果11pro max微信怎么加密(苹果11promax微信来消息没声音)

  • 抖音怎么删除失效视频(抖音怎么删除失效收藏的商品)

    抖音怎么删除失效视频(抖音怎么删除失效收藏的商品)

  • Word自动生成目录怎么设置字体(word自动生成目录对不齐)

    Word自动生成目录怎么设置字体(word自动生成目录对不齐)

  • 抖音成年版在哪里(抖音成年版在哪下载安装)

    抖音成年版在哪里(抖音成年版在哪下载安装)

  • 联想保修期多久(联想保修期内维修要钱吗)

    联想保修期多久(联想保修期内维修要钱吗)

  • watch5发布时间(apple watch5发布价格)

    watch5发布时间(apple watch5发布价格)

  • wifi扩展器的坏处(wifi扩展器感觉没什么用)

    wifi扩展器的坏处(wifi扩展器感觉没什么用)

  • 微信运动步数怎么显示在屏幕上(微信运动步数怎么刷才能几万步)

    微信运动步数怎么显示在屏幕上(微信运动步数怎么刷才能几万步)

  • 微信如何删除多个会话(微信如何删除多余的头像和昵称)

    微信如何删除多个会话(微信如何删除多余的头像和昵称)

  • 美版合约机国内能用吗(美版的合约机)

    美版合约机国内能用吗(美版的合约机)

  • hp403d硒鼓的型号(惠普403硒鼓)

    hp403d硒鼓的型号(惠普403硒鼓)

  • oppo手机怎样强制关机(oppo手机怎样强制关机重启)

    oppo手机怎样强制关机(oppo手机怎样强制关机重启)

  • iOS13如何设置来电闪光灯(ios13如何设置来电小头像)

    iOS13如何设置来电闪光灯(ios13如何设置来电小头像)

  • iphone11怎么查看电池损耗情况(iphone11怎么查看照片大小)

    iphone11怎么查看电池损耗情况(iphone11怎么查看照片大小)

  • 京东消息提醒怎么取消(京东消息提醒怎么关掉)

    京东消息提醒怎么取消(京东消息提醒怎么关掉)

  • 微博我的访问记录怎么删除不了(微博我的访问记录仅自己可见什么意思)

    微博我的访问记录怎么删除不了(微博我的访问记录仅自己可见什么意思)

  • 未接通是什么意思啊(号码未接通)

    未接通是什么意思啊(号码未接通)

  • 苹果11还是刘海屏吗(苹果11刘海是什么意思)

    苹果11还是刘海屏吗(苹果11刘海是什么意思)

  • 什么情况下用选择性粘贴(什么情况下选择第二中标人)

    什么情况下用选择性粘贴(什么情况下选择第二中标人)

  • 电脑word页面设置在哪(电脑word页面设置在哪里找?)

    电脑word页面设置在哪(电脑word页面设置在哪里找?)

  • oppo手机隐藏桌面图标的密码怎么修改(oppo手机隐藏桌面图标怎么找出来)

    oppo手机隐藏桌面图标的密码怎么修改(oppo手机隐藏桌面图标怎么找出来)

  • 手机贴吧的链接怎么打开(手机贴吧的链接在哪里)

    手机贴吧的链接怎么打开(手机贴吧的链接在哪里)

  • 没有权限使用网络资源(没有权限使用网络资源,请与这台服务器的管理员联系)

    没有权限使用网络资源(没有权限使用网络资源,请与这台服务器的管理员联系)

  • 工业企业取得土地使用权专用发票可以抵扣吗?
  • 怎么查历年
  • 法人购买商业保险能由公司承担吗
  • 财产租赁个人所得税
  • 接受非货币性资产捐赠以其什么确认捐赠额
  • 预收电费结转成本怎么办
  • 没有发票合法吗
  • 销售合同总金额含税还是不含税
  • 个人交的税费报销如何做账?
  • 小规模纳税人简易计税方法
  • 学校应该缴纳的税
  • 非盈利组织纳税筹划
  • 停车费属于不动产租赁服务税率
  • 固定资产划转要交增值税吗
  • 企业的商誉会一直存在吗
  • 公司奖励员工旅游怎么做账
  • 购买东西收据
  • 有限责任公司向合伙企业投资
  • 发票查出来显示不一致是为啥
  • win11界面不停刷新
  • 个体户开劳务费发票需要交哪些税
  • cmos密码和bios密码
  • 服务器centos6.9安装教程
  • 怎么用U盘装系统win7
  • 在win7系统中怎样卸载win10?
  • linux用不了yum
  • 业务招待费汇算清缴扣除标准
  • win10开机启动文件夹目录说明
  • 增值税已认证抵扣
  • 购入固定资产款项已付
  • 会计年报表怎么做
  • 工资必须走银行卡吗
  • 魔改toolbox
  • javascript基础类型
  • 命令行find
  • 钱进公账怎么转账给别人
  • 固定资产计提折旧的方法
  • 当月增加的房产 要交房产税吗
  • 不想预缴所得税交多了怎样先把利润转到费用
  • 红冲后的发票税怎么办
  • dedecms安装步骤
  • mongodb常见问题
  • 销售公司提成表模板
  • 递延所得税资产和负债怎么计算
  • 所得税费用是指
  • 增值税一般纳税人是什么意思
  • 垃圾处理费如何做账
  • 没有海关完税凭证怎么入账
  • 销项税和进项税的区别
  • 坏账确认无法收回
  • 一个工程项目多个业主吗
  • 建筑企业成本核算方法
  • 代发工资的手续流程
  • 物业公司付电业费合法吗
  • 过路费油费计入什么费用
  • 非公司员工可以发提成吗
  • 现金投资属于什么会计科目
  • 设备基础属于什么基础
  • 会计常用表格都有哪些技能
  • 我国开征股票交什么税
  • 诺诺开票人怎么修改
  • 建账有哪些步骤,每个步骤有哪些注意事项
  • win10企业版怎么连接无线网
  • Linux的bg和fg命令简单介绍
  • linux常用性能监控命令
  • linux %1
  • win80xc0000001怎么修复
  • win10怎么关闭讲述人模式
  • quick cocos2dx-Lua中的自定义事件的使用
  • node_modules复制
  • nodejs实战
  • rpg游戏脚本已经被备份
  • JavaScript中的math.pi
  • 如何用jquery
  • 设计模式具有的优点
  • 聊天界面的新消息通知设置 找不到
  • 车船税的纳税期限是
  • 房屋契税2013年收费标准
  • 税务局无编制人员工资
  • 杭州市各区面积人口排名
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设