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

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

  • 360安全卫士主动防御怎么关闭(360安全卫士主动防御开启失败)

    360安全卫士主动防御怎么关闭(360安全卫士主动防御开启失败)

  • 微信右上角三个点,没 了怎么办(微信右上角三个点隐藏)

    微信右上角三个点,没 了怎么办(微信右上角三个点隐藏)

  • wps如何持续输入红色的字(wps怎样实现输入后自动锁定)

    wps如何持续输入红色的字(wps怎样实现输入后自动锁定)

  • 苹果手机电池健康低于多少免费更换(苹果手机电池健康80%需要换电池吗)

    苹果手机电池健康低于多少免费更换(苹果手机电池健康80%需要换电池吗)

  • 苹果h1和w1的区别(苹果w1和h1芯片的区别)

    苹果h1和w1的区别(苹果w1和h1芯片的区别)

  • 拼多多退换货怎么操作(拼多多退换货怎么取消)

    拼多多退换货怎么操作(拼多多退换货怎么取消)

  • 怎么关闭指纹解锁功能(怎么关闭指纹解锁功能华为手机)

    怎么关闭指纹解锁功能(怎么关闭指纹解锁功能华为手机)

  • 分页符的作用是什么(分页符作用是分页吗)

    分页符的作用是什么(分页符作用是分页吗)

  • 苹果手机直播卡的原因(苹果手机直播卡顿)

    苹果手机直播卡的原因(苹果手机直播卡顿)

  • 什么软件能把视频拼接在一起(什么软件能把视频清晰度提高)

    什么软件能把视频拼接在一起(什么软件能把视频清晰度提高)

  • 微光可以自己上传视频吗(微光自己上传电影)

    微光可以自己上传视频吗(微光自己上传电影)

  • qq语音限制人数吗(qq语音聊天上限)

    qq语音限制人数吗(qq语音聊天上限)

  • 隔空投送一次能传多少照片(隔空投送一次能传多少张)

    隔空投送一次能传多少照片(隔空投送一次能传多少张)

  • 手机版微信热键冲突怎么修改(微信热键被占用不改有影响吗)

    手机版微信热键冲突怎么修改(微信热键被占用不改有影响吗)

  • 怎样把照片内存增大(怎样把照片内存改小一点)

    怎样把照片内存增大(怎样把照片内存改小一点)

  • 拼多多差评怎样修改(拼多多怎么求评价)

    拼多多差评怎样修改(拼多多怎么求评价)

  • 操作系统知识点

    操作系统知识点

  • realmex有红外吗(realme有没有红外遥控)

    realmex有红外吗(realme有没有红外遥控)

  • lte高速率模式有什么用(什么叫lte高速上网功能)

    lte高速率模式有什么用(什么叫lte高速上网功能)

  • 三星s10可以快充吗(三星s10快充多久可以充满)

    三星s10可以快充吗(三星s10快充多久可以充满)

  • 怎样从Win11中删除 Microsoft 帐户?Win11中删除Microsoft帐户详细步骤(如何删除win11的入门)

    怎样从Win11中删除 Microsoft 帐户?Win11中删除Microsoft帐户详细步骤(如何删除win11的入门)

  • sxgdsenu.exe - sxgdsenu是什么进程 有什么用

    sxgdsenu.exe - sxgdsenu是什么进程 有什么用

  • AJAX中的跨域(CORS) 问题 (更新于2023.02.04)(ajax跨域请求的原理是什么)

    AJAX中的跨域(CORS) 问题 (更新于2023.02.04)(ajax跨域请求的原理是什么)

  • 税务机关代开的增值税发票要加盖发票专用章吗?
  • 个人出租房屋的个人所得税税率
  • 增值税抵扣了还能作废吗
  • 按月支付劳务费开发票
  • 无形资产多摊销了怎么办
  • 往来票据如何开具
  • 收入与支出的差异
  • 饭店采购食材没发票
  • 小微企业如何申请土地建厂房
  • 年薪12万个人所得税交多少钱
  • 拿到进项票下一步做啥
  • 代缴水电费是什么意思
  • 公司账上收到退回的多交的附加税怎么做
  • 个人投资者
  • 公司注销时存货计税依据
  • 会计当年是指哪一年
  • 研发费用申报表汇算清缴怎么填
  • 推广费属于什么科目
  • 网速突然变差是什么原因
  • win7系统中如何关闭触摸屏声音
  • PHP:pg_options()的用法_PostgreSQL函数
  • 谷歌网页小恐龙
  • 使用二氧化碳灭火器时人应该站在什么位置
  • php连接数据库实现登录注册
  • 发生的计提费用没有发生怎么办
  • 一般纳税人与小规模纳税人在报税方面的区别
  • php匿名函数和回调函数
  • 创造未来这首歌是谁
  • continue命令必须与locate
  • super命令linux
  • 用友u8反结账反记账的操作步骤
  • 微擎框架是开源的吗
  • php文件怎么浏览
  • 什么发票才能做账务处理
  • 长期待摊费用的摊销分录
  • 运输发票备注栏里一般需要备注的内容包括
  • 节日购买什么礼物发放职工
  • sql server中数据文件的扩展名是
  • 将原生html改成vue
  • 运费发票有普票吗
  • 代收代缴水费收不上来怎么办
  • 摄影的服务注册是什么
  • 公司成立开的户叫什么
  • 企业待摊费用怎么计算
  • mysql复制数据到另一张表
  • 应收票据及应收账款包括哪些科目
  • 小规模申报表填写模板
  • 所得税费用需要结转损益吗
  • 企业购买了数千亿资产
  • 小规模纳税人减按1%如何填报申报表
  • 会计准则允许预提吗
  • 应纳税工资是应发还是实发
  • 贷款服务有哪些项目
  • 进项税额转出加计抵减填在哪里
  • 工程未完工,费用怎么处理
  • mysql使用or会索引
  • mysql安装配置教程5.7.25
  • mysqli修改表中数据
  • mysql索引用法
  • win8系统中断怎么解决
  • 修改windows host文件
  • award bios设置图解教程
  • wmpdmc.exe是什么意思
  • win8.1 升级
  • linux批量ping
  • errorlnk2019怎么解决
  • android界面切换与数据传递
  • accessviolation怎么解决
  • jquery三种遍历方法
  • 透明十六进制
  • 原生js实现ajax步骤
  • unity she
  • unity3d相机设置视角
  • python 两个列表一一对应
  • 如何用javascript
  • 河北地方税务局网
  • 长沙房产税如何征收
  • 什么是美国注册商标
  • 目前长沙二手房出售信息
  • 如何网上办税票
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设