当前位置: 首页 > wzjs >正文

动易网络 官方网站网络优化工程师证书

动易网络 官方网站,网络优化工程师证书,开发网站价格,花都电子商务网站建设目前网上,包括官方文档针对uniapp的webview的内容都是基于vue2的,此文章基于vue3的composition API方式网页对网页 由于uniapp中的webview只支持引入h5页面,不支持互相通信,所以要条件编译,用iframe导入页面&#xf…

目前网上,包括官方文档针对uniapp的webview的内容都是基于vue2的,此文章基于vue3的composition API方式

网页对网页   

由于uniapp中的webview只支持引入h5页面,不支持互相通信,所以要条件编译,用iframe导入页面,并通信  

父页面

<!-- #ifdef H5 --><iframesrc="http://192.168.0.105:5000/#/index"border="none"width="100%"height="100vh"frameborder="0"style="border: none; height: calc(100vh - 8px)"ref="iframe"@load="handlePageLoaded"></iframe><!-- #endif -->
const iframe = ref()  
const handlePageLoaded = () => {console.log('h5端网页加载成功')iframe.value.contentWindow.postMessage({type: 'Function', // 调用方法from: 'uniapp',functionName: 'appCallback',params: {from: 'uniapp h5',},},'*',) // 需指定子页面域名// 调用子页面全局方法(同源才行)// iframe.value.contentWindow.appCallback({ name: 'tom' })
}// #ifdef H5
// 监听子页面的返回结果
window.addEventListener('message', function (event) {if (event.data?.from == 'h5') {console.log('uniapp收到iframe发来消息', event.data)}
})
// #endif

子页面  

window.addEventListener('load', function () {console.log('子页面(被iframe嵌入)所有资源加载完成!');// 这里可以执行加载完成后的操作(如初始化、发送消息给父页面等)});window.addEventListener('message', function (event) {// 验证消息来源if (event.data?.from == 'uniapp') {const message = event.data;event.source.postMessage({type: 'functionResult',from: 'h5'}, event.origin);if (message.functionName) {window[message.functionName](message.params || {})}console.log('iframe收到uniapp消息', message)}});

网页对app或者小程序 

子页面  

引入uniapp官方文档提供的js文件  

  <script src="/lib/uni.webview.js"></script>
// 待触发 `UniAppJSBridgeReady` 事件后,即可调用 uni 的 API。document.addEventListener('UniAppJSBridgeReady', function () {console.log('uniapp中webview加载完成')uni.getEnv(function (res) {console.log('当前环境:' + JSON.stringify(res));setTimeout(() => {if (res.h5) {// uniapp不支持h5之间用webview互相通信} else if (res.plus) {uni.postMessage({data: {action: 'message',other: {name: 'ike',age: 30}}});}}, 200)});// 发送消息// uni.postMessage({//   data: {//     action: 'message'//   }// });});

父应用  

import { onReady } from '@dcloudio/uni-app'
import { getCurrentInstance } from 'vue'const wv = ref()
onReady(() => {// #ifndef H5setTimeout(() => {wv.value = instance?.proxy.$scope.$getAppWebview().children()[0]}, 100)// #endif
})const handleWVMessage = (ev: any) => {console.log('收到web消息', ev.detail.data)wv.value.evalJS(`appCallback({action: 'message', data: {name: 'tom'}})`)
}

目前存在问题

1、app端无法使用load监听网页是否加载完成,小程序端可以  

2、页面ready后,要延时一阵才能拿到真正的webview实例,所以网页端监听到加载完毕,也要延时一阵再给uniapp发消息  

http://www.dtcms.com/wzjs/182250.html

相关文章:

  • dede网站移动端怎么做google官方入口
  • 网站开发与设计入门seo网站排名优化公司哪家
  • 有没有跟一起做网店一样的网站保定百度推广联系电话
  • e盒印网站开发生成关键词的软件
  • 做私彩网站代理会坐牢吗网站排名优化+o+m
  • 自己做视频网站会不会追究版权做网站需要哪些技术
  • 滁州网站建设公司广东今日最新疫情通报
  • 免费销售网站模板下载百度网页版怎么切换
  • 公司部门英语seo常用工具包括
  • 网站开发公司海报网站开发技术
  • 给网站做压力测试最近一周的重大新闻
  • 克拉玛依市建设局官方网站百度推广400电话
  • 恒通建设集团有限公司网站长沙专业竞价优化公司
  • 供求网站建设seo线上培训多少钱
  • 网站建设多少钱一年上首页seo
  • 兰州网站建设公企业宣传方式有哪些
  • 温州建网站公司石家庄百度seo
  • 张家港快速网站建设sem公司
  • 网站运营推广怎么做人工智能培训心得体会
  • 成都网站建设 推广行网站seo的优化怎么做
  • 网站特效模板常德网站设计
  • 做seo要明白网站北京做网页的公司
  • 中企动力做的网站被百度屏蔽seo快速排名是什么
  • 茶百道加盟费大概要多少安卓神级系统优化工具
  • 支付宝网站接口申请百度云资源搜索平台
  • 东莞资深网站建设杭州百度快照优化排名推广
  • 有哪些可以做推广的网站互联网广告怎么做
  • xampp部署wordpress企业seo排名费用报价
  • 嘉定品牌网站建设合肥优化营商环境
  • 网站建设工作内容百度代理查询系统