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

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

  • pcnm00是oppo哪个型号(oppopcnm00是什么型号手机)

    pcnm00是oppo哪个型号(oppopcnm00是什么型号手机)

  • 华为插耳机老是跳出语音助手(华为插耳机老是跳歌曲)

    华为插耳机老是跳出语音助手(华为插耳机老是跳歌曲)

  • 微信视频对方忙线中是怎么回事(微信视频对方忙线是在干嘛)

    微信视频对方忙线中是怎么回事(微信视频对方忙线是在干嘛)

  • 苹果se2多少寸(苹果se2是多少寸的)

    苹果se2多少寸(苹果se2是多少寸的)

  • POS机是什么(0.38pos机是什么)

    POS机是什么(0.38pos机是什么)

  • 微信验证50个字能看到吗(微信验证50个字能全部看到吗?)

    微信验证50个字能看到吗(微信验证50个字能全部看到吗?)

  • 微信不能付款怎么回事(微信不能付款怎么解封)

    微信不能付款怎么回事(微信不能付款怎么解封)

  • ipad mini5尺寸(ipad mini5尺寸一览表)

    ipad mini5尺寸(ipad mini5尺寸一览表)

  • qq消息声音突然不响了(为什么qq消息声音小)

    qq消息声音突然不响了(为什么qq消息声音小)

  • airpods丢了一只能配吗(airpods丢了一只怎么找回来)

    airpods丢了一只能配吗(airpods丢了一只怎么找回来)

  • vivonex3怎么截屏(vivonex3怎么截屏视频教程)

    vivonex3怎么截屏(vivonex3怎么截屏视频教程)

  • 快手押金500可以退吗?(快手交押金多久可以卖东西)

    快手押金500可以退吗?(快手交押金多久可以卖东西)

  • 洋淘买家秀是什么意思(淘宝店铺洋淘买家秀)

    洋淘买家秀是什么意思(淘宝店铺洋淘买家秀)

  • wps权限设置在哪里解除(wps权限设置在哪里)

    wps权限设置在哪里解除(wps权限设置在哪里)

  • 联想14和14air区别(联想air14和thinkpad)

    联想14和14air区别(联想air14和thinkpad)

  • qq举报几次会封号(qq举报几次会永久封号)

    qq举报几次会封号(qq举报几次会永久封号)

  • word怎么让数字竖着(word怎么让数字变成会计专用)

    word怎么让数字竖着(word怎么让数字变成会计专用)

  • 怎么取消淘宝预售订单(怎么取消淘宝预约提醒)

    怎么取消淘宝预售订单(怎么取消淘宝预约提醒)

  • 苹果耳机怎么调按下一首(苹果耳机怎么调节降噪模式)

    苹果耳机怎么调按下一首(苹果耳机怎么调节降噪模式)

  • ps图片怎么镜像翻转(ps图片怎么镜像翻转过来)

    ps图片怎么镜像翻转(ps图片怎么镜像翻转过来)

  • 怎么查看误删的微信聊天记录(怎么查看误删的qq好友)

    怎么查看误删的微信聊天记录(怎么查看误删的qq好友)

  • appleipadair3尺寸(iphone air3尺寸)

    appleipadair3尺寸(iphone air3尺寸)

  • 华为mate怎么看出厂日期(华为mate怎么看电池健康)

    华为mate怎么看出厂日期(华为mate怎么看电池健康)

  • qq自动回复怎么删除(qq自动回复怎么关闭)

    qq自动回复怎么删除(qq自动回复怎么关闭)

  • 手机上如何打开vob(手机上如何打开网页版)

    手机上如何打开vob(手机上如何打开网页版)

  • 帝国cms怎么多条件搜索(帝国cms界面)

    帝国cms怎么多条件搜索(帝国cms界面)

  • 附加税减免要做哪些科目
  • 个税申报表中本期收入怎么填
  • 库存股增加为什么资产减少
  • 营业税金及附加包括增值税吗
  • 个人非专利技术转让属于什么收入
  • 存货非正常损失的纳税筹划
  • 超范围经营可以赔偿吗
  • 公司配股后,会迅速提高公司股票市价
  • 公司的基建部门是做什么的
  • 开出产品折扣的发票怎么入账?
  • 内账的成本结转含税还是不含税?
  • 税局定额的标准
  • 企业年报资产状况信息可以不填吗
  • 以前年度损益调整贷方余额表示什么
  • 税款已入库,申报错误更正可以吗
  • 回迁安置房税收优惠
  • 高新技术企业研发费
  • 公司固定资产一般谁负责
  • 1697510586
  • 结转利润分配分录怎么写
  • 去年收入少做了怎么调账
  • 人力资源管理师考试时间
  • 上年超额广告费会计分录
  • 发生销售折让会计分录
  • 汇率调整怎么做分录
  • win11怎么压缩图片画质
  • 收藏的php常用函数是什么
  • searchnav.exe - searchnav是什么进程 有什么用
  • 未办理装修手续
  • 公积金怎么做会计科目
  • 企业常见的筹资方式有几种
  • 企业如何避免纳税问题
  • 投资担保公司的钱都去哪了
  • php中文字符串截取
  • 如何更改telnet端口
  • Python如何检测两个相同的列表
  • 管家婆实收资本显示负数什么原因
  • access中宏的操作
  • 归还股东借款要交税吗
  • 公司向公司借款合法吗
  • 长期股权投资成本法会计处理
  • 简述sql server 2008的新增功能
  • 建筑施工仪器设备有哪些
  • 员工借款属于什么现金流量
  • 运费不支付会怎么样
  • 销售方会计分录
  • 公司增资怎么处理
  • 替其他公司支付工资怎么做账
  • 企业法人投资收益交税吗
  • 广告赞助的形式
  • 筹建期开办费明细
  • 会计档案销毁方案怎么写
  • 什么是格式良好的xml文档
  • 路由怎么配
  • 开始菜单字体
  • windows 2000.
  • u盘安装win7系统教程图解
  • 电脑的本地连接在哪win10
  • 系统盘gpt转mbr
  • win10系统任务栏卡顿
  • mac桌面应用
  • ubuntu ftp服务器怎么搭建
  • linux判断程序是否运行
  • win7win10双硬盘双系统
  • win10系统怎么设置默认打印机
  • nodejs使用视频教程
  • 安卓listview用法
  • 使用jquery的步骤
  • js选择框全选
  • jquery监听页面刷新
  • js原生方法大全
  • android的布局文件
  • python运行py文件没反应
  • chrome excel
  • jQuery xml字符串的解析、读取及查找方法
  • 国家税务局总局广东省电子税务局官网
  • 退发票操作流程
  • 利润报表怎么填写
  • 停车票日期在哪里
  • 用户卡,税控卡怎么办理
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设