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

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

  • 苹果手表输入法怎么设置(苹果手表输入法怎么改成中文)

    苹果手表输入法怎么设置(苹果手表输入法怎么改成中文)

  • win10如何解压rar文件(win10如何解压pkg文件)

    win10如何解压rar文件(win10如何解压pkg文件)

  • word如何设置左对齐(word如何设置左右缩进)

    word如何设置左对齐(word如何设置左右缩进)

  • 电脑修改照片格式为jpg怎么弄(电脑修改照片格式的软件)

    电脑修改照片格式为jpg怎么弄(电脑修改照片格式的软件)

  • 小米双击唤醒屏幕不灵(小米双击唤醒屏幕耗电吗)

    小米双击唤醒屏幕不灵(小米双击唤醒屏幕耗电吗)

  • 咸鱼看得出是谁举报的嘛(闲鱼可以知道谁看了我的主页了吗)

    咸鱼看得出是谁举报的嘛(闲鱼可以知道谁看了我的主页了吗)

  • vivos6相机功能(vivo s6相机)

    vivos6相机功能(vivo s6相机)

  • 抖音前面的蓝色话筒是什么(抖音前面的蓝色等级)

    抖音前面的蓝色话筒是什么(抖音前面的蓝色等级)

  • 怎样在微信位置上添加自己的店名(怎样在微信位置里设置自己的位置)

    怎样在微信位置上添加自己的店名(怎样在微信位置里设置自己的位置)

  • 6s可以升级13.4吗(iphone6s能不能升级13)

    6s可以升级13.4吗(iphone6s能不能升级13)

  • 拼多多类目可以改吗(拼多多类目怎么选择)

    拼多多类目可以改吗(拼多多类目怎么选择)

  • 如何减少微信异常和封号(如何减少微信异常状态)

    如何减少微信异常和封号(如何减少微信异常状态)

  • 京豆赠送在订单能看到吗(京东赠送的京豆订单里会显示吗)

    京豆赠送在订单能看到吗(京东赠送的京豆订单里会显示吗)

  • 小米cc9pro要不要贴膜

    小米cc9pro要不要贴膜

  • qq达人最多能补几天(qq达人一天能补几次)

    qq达人最多能补几天(qq达人一天能补几次)

  • qq号查找是什么意思(qq查找和账号查找)

    qq号查找是什么意思(qq查找和账号查找)

  • 华为灭屏显示费电吗(华为手机灭屏显示浪费电吗)

    华为灭屏显示费电吗(华为手机灭屏显示浪费电吗)

  • 小米8青春版快充设置(小米8青春版快速充电)

    小米8青春版快充设置(小米8青春版快速充电)

  • 三星note10无线充电多少w(三星note10无线充电已暂停)

    三星note10无线充电多少w(三星note10无线充电已暂停)

  • 苹果11pro max什么时候开售(苹果11promax什么时候开售的)

    苹果11pro max什么时候开售(苹果11promax什么时候开售的)

  • 快手500播放量算热门吗(快手播放量500到600什么意思)

    快手500播放量算热门吗(快手播放量500到600什么意思)

  • 抖音隐藏随拍是不是看不到作品了(抖音隐藏随拍是什么)

    抖音隐藏随拍是不是看不到作品了(抖音隐藏随拍是什么)

  • 关于HTML中表格单元格的合并(html表格用法)

    关于HTML中表格单元格的合并(html表格用法)

  • React的受控组件和非受控组件介绍(react受控和不受控组件的区别)

    React的受控组件和非受控组件介绍(react受控和不受控组件的区别)

  • python多进程中多个参数函数的使用(python2多进程)

    python多进程中多个参数函数的使用(python2多进程)

  • 财务软件怎么样从捷软系统导出数据
  • 暂估入库收到发票后怎么做分录
  • 个体工商户免费刻章
  • 个税身份验证不通过
  • 买什么样的房子可以贷款
  • 建筑行业简易计税账务处理
  • 季度流动比率怎么算
  • 会计中预付款包括
  • 怎么填报清算所得税申报表?
  • 关于预计负债应付退货款明细科目
  • 补发工资是否需要交税
  • 什么是个体工商户业主
  • 旧税号的发票专用章还能使用吗
  • 技术转让怎么算成本
  • 请问哪些福利费不用交税
  • 累计折旧属于什么
  • 公司筹建期间的劳务费怎么入账
  • 广告服务类企业有哪些
  • win7鼠标点右键没反应
  • 贴现利息会计处理
  • 补助是按基本工资还是总工资
  • 固定资产的折旧是什么意思
  • 花卉盆景苗木
  • psr.exe是什么意思
  • 王者荣耀中刘邦技能解析以及如何连招
  • macbook视频怎么用
  • 个人减免税政策6条
  • mom.exe是什么
  • Yii使用技巧大汇总
  • 二手商铺的税费太高了吧
  • 固定资产的折旧怎么算
  • 成本法的优点是计算较为简便,缺点是
  • 公民什么情况纳税
  • 企业常见的筹资方式有几种
  • 制造企业的印花税税率
  • 隐隐作痛怎么写
  • 企业所得税的计提和缴纳分录
  • 低代码框架开发
  • vue实战技巧
  • 安装多版本chrome
  • 多交的城建税可以抵减扣除吗
  • 制造费用体现在哪些方面
  • 农村土地承包经营权流转合同
  • 金融资产的转换
  • 城镇土地使用税优惠政策
  • 公司承担员工的社保费会计分录
  • phpcms v9用户手册
  • 承债式股权转让
  • 预支报销单
  • 企业的所得税税率怎么计算
  • 金税盘 申报
  • 开票航天信息要交年费吗
  • 对于产品开发阶段的评价
  • 出口后收不到货款
  • 营改增进程
  • 个体户减免税额怎么填
  • 小规模纳税人收入是含税还是不含税
  • 事业单位预收账款
  • 委托加工的成本如何核算
  • sql中的递归
  • mysql分页性能
  • gridview自定义排序
  • windows导航栏在左边
  • 微软推出windows1
  • 解决口苦最快的方法
  • 联想昭阳k41笔记本
  • txt无法打开怎么弄
  • windows一键安装
  • imac触发角
  • 怎么使用mac打电话
  • windows xp快捷键设置在哪
  • win8远程桌面连接设置
  • win7系统怎么关闭屏幕保护
  • perl 教程
  • python3循环语句
  • github常用操作
  • macos mono
  • python数据操作
  • javascript有几种类型
  • 建筑施工税务处理
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设