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

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

  • 联想小新air14键盘灯怎么打开(联想小新air14键盘亮屏幕不亮)

    联想小新air14键盘灯怎么打开(联想小新air14键盘亮屏幕不亮)

  • iqoou1充电口是什么类型(iqoou1是什么充电接口)

    iqoou1充电口是什么类型(iqoou1是什么充电接口)

  • u30什么意思(田径u30什么意思)

    u30什么意思(田径u30什么意思)

  • 华为手机那个圆圈怎么设置(华为手机那个圆圈怎么关掉)

    华为手机那个圆圈怎么设置(华为手机那个圆圈怎么关掉)

  • 微信收款码有限额吗(微信收款码有限制次数吗)

    微信收款码有限额吗(微信收款码有限制次数吗)

  • 华为手机变声器在哪里(华为手机变声器怎么关闭)

    华为手机变声器在哪里(华为手机变声器怎么关闭)

  • 一部手机能申请几个健康码(一部手机能申请两个支付宝吗)

    一部手机能申请几个健康码(一部手机能申请两个支付宝吗)

  • 朋友圈为什么不能点赞评论(朋友圈为什么不能发长视频)

    朋友圈为什么不能点赞评论(朋友圈为什么不能发长视频)

  • 华为p30情景智能怎么打开(华为p30情景智能设置)

    华为p30情景智能怎么打开(华为p30情景智能设置)

  • 闲鱼申请退款多久到账(闲鱼申请退款多久自动退款)

    闲鱼申请退款多久到账(闲鱼申请退款多久自动退款)

  • 华为手机怎么弄两个界面(华为手机怎么弄俩微信)

    华为手机怎么弄两个界面(华为手机怎么弄俩微信)

  • 抖音怎么查看所有送礼记录(抖音怎么查看所有关注的人)

    抖音怎么查看所有送礼记录(抖音怎么查看所有关注的人)

  • 手机视频太长怎么发送微信朋友(手机视频太长怎么剪辑)

    手机视频太长怎么发送微信朋友(手机视频太长怎么剪辑)

  • 打印机不用的时候需要关闭吗(打印机不用的时候要关机吗)

    打印机不用的时候需要关闭吗(打印机不用的时候要关机吗)

  • 苹果11pro基带是高通的吗(苹果11pro基带多少钱)

    苹果11pro基带是高通的吗(苹果11pro基带多少钱)

  • 快手删几个作品怎么恢复(快手删几个作品会限流吗)

    快手删几个作品怎么恢复(快手删几个作品会限流吗)

  • 淘宝直播屏蔽设置在哪里(淘宝直播间屏蔽)

    淘宝直播屏蔽设置在哪里(淘宝直播间屏蔽)

  • 淘宝的销量是真实的吗(淘宝上面销量都是真实的吗?)

    淘宝的销量是真实的吗(淘宝上面销量都是真实的吗?)

  • 滴滴出行拼成价什么意思(滴滴出行拼成价是什么意思)

    滴滴出行拼成价什么意思(滴滴出行拼成价是什么意思)

  • airpods刻字了还能退吗(airpods刻字了还能换吗)

    airpods刻字了还能退吗(airpods刻字了还能换吗)

  • imessage怎么放烟花

    imessage怎么放烟花

  • 怎样解除手机紧急呼叫(怎样解除手机紧急电话)

    怎样解除手机紧急呼叫(怎样解除手机紧急电话)

  • 魅族16s如何关机(魅族16x怎么关机重启)

    魅族16s如何关机(魅族16x怎么关机重启)

  • uc浏览器的隐私相册在哪(uc浏览器的隐私空间怎样加锁)

    uc浏览器的隐私相册在哪(uc浏览器的隐私空间怎样加锁)

  • 苹果7volte在哪里设置(苹果7手机volte哪里开启)

    苹果7volte在哪里设置(苹果7手机volte哪里开启)

  • 为什么打印出来只有一半(为什么打印出来没有框线)

    为什么打印出来只有一半(为什么打印出来没有框线)

  • 什么是企业的命脉
  • 软件研发阶段和开发阶段如何区分
  • 销售使用过的固定资产放弃减税
  • 投资收益科目在贷方
  • 新成立的公司一般纳税人还是小规模纳税人好
  • 不带息票据贴现计算公式
  • 公司分期付款买车可以抵税吗
  • 企业购入旧固定资产如何计提折旧
  • 在建工程转固后又发生成本
  • 一般纳税人销售二手车增值税税率
  • 地址变更工商局上门检查
  • 第一季度时间范围
  • 股份有限公司发行的股票溢价
  • 境外个人所得税计算
  • 人身意外保险费可以扣除企业所得税吗
  • 应收款收不回账务处理
  • 普票红字发票怎么写摘要
  • 内外账合并步骤
  • 购进商品没收到货怎么办
  • 已核销的应收账款
  • 普通增值税发票跨越可以作废吗
  • 投资收益亏损后会怎么样
  • 企业预收账款缴哪些税
  • php能开发微信小程序吗
  • 公司购买自己公司的产品
  • 建筑业开具发票
  • 销售产品应交的消费税分录
  • 工业企业在进行材料采购
  • 赔偿金和违约金有什么区别
  • elementui
  • Notojima岛附近的牡蛎养殖场,日本石川县 (© divedog/Shutterstock)
  • 服务费可以暂估成本吗
  • 物业代收代缴费 没住户怎么办
  • 其他应收款抵货款怎么记账
  • 所得税弥补亏损年限10
  • 金蝶kis的使用方法
  • 一般纳税人都是按月申报吗
  • 织梦收费5800的解决方法
  • 银行手续费和利息会计分录
  • 生产车间发生的费用计入什么科目
  • 个人所得税专项附加扣除2023
  • 员工的生日津贴怎么发
  • 备用金有发票抵扣吗
  • t3怎么查资产负债表
  • 职工薪酬实际发生额忘记填会有风险吗
  • 营改增行业销售额的确定
  • 暂估入库的税务怎么处理
  • 以自营方式建造固定资产
  • 其它综合收益包括
  • 质量问题扣货款会计怎么处理
  • 销售费属于期间费用
  • 购买电脑配件组件怎么选
  • 绿化植物税率
  • 代扣的应由职工个人负担的社会保险费计入什么科目
  • 行政单位如何做好机构编制工作
  • 手工账的做账流程图
  • cf分屏不全屏
  • windows vista如何升级
  • win7访问共享文件
  • Win10 Build 10565快速预览版为什么有ISO镜像下载地址?
  • windows xp自带
  • xp输入法图标消失
  • Win7任务栏时间显示秒
  • fpassist.exe是什么进程 有什么作用 fpassist进程查询
  • win7系统无法开机解决方法
  • win8.1卸载软件在哪里
  • linux配置静态
  • android通知消息
  • 开快打开
  • JavaScript运算符都有哪些
  • emulator: ERROR: no search paths found in this AVD's configuration. Weird, the AVD's config.ini file
  • linux生成文件
  • jQuery on绑定的事件
  • node爬取数据
  • 游戏引擎在游戏开发中的核心作用
  • 山西地方税务局领导班子
  • 全年一次性奖金怎么申报个税
  • 2008年深圳房价崩盘
  • 如果快递没有按时发货东西变质怎么办
  • 高端护肤品品牌排行榜
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设