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

网络营销怎么做网站邢台泰尚网络科技有限公司

网络营销怎么做网站,邢台泰尚网络科技有限公司,WordPress干什么的,营销软件培训目前网上,包括官方文档针对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/a/546009.html

相关文章:

  • 多级缓存系统设计:从本地到分布式,打造高性能利器
  • 网站建设企业建站哪家好wordpress 红包广告
  • VS的Qt项目在Git拉取后丢失QT的项目设置
  • 北京公司建网站要多少费用电脑网站生成手机网站
  • 怎么做盗版电影网站吗免费做网站哪里有
  • erd-editor:一款免费开源的ERD设计工具
  • 如何查看一个网站是什么程序做的住宅装饰装修工程施工规范
  • 网站空间企业个人网页设计需要考什么证书
  • 2025青科会启幕,网易伏羲携游戏AI前沿实践共话未来
  • 网站建设领先广州代做网站
  • 聊网站推广免费下载一个app
  • 深圳电商网站制作公司郑州二七区做网站
  • vue路径大小写引入检查与修复;配置git大小写敏感
  • 赣州网站开发公司网站开发的重难点
  • dvadmin开发文档(第一版)
  • 设计网站视频教程长沙网站推广优化
  • 淘宝电子面单API集成中的常见技术难点与解决方案
  • 高端网站制作要多少钱河北网站开发公司
  • 电脑制作网站的软件免费发布信息平台网
  • 西宁网站seo价格永康企业网站建设公司
  • 做视频特技的网站网站字体排版技巧
  • Rust 的零成本抽象:深入理解 Option 与 Result 的设计哲学
  • rust:什么是所有权
  • 模版网站好吗搜索引擎最新排名
  • 【js逆向案例二】瑞数6 深圳大学某医院
  • 网站编辑怎么样东莞网站建设网站推广价钱
  • TypeScript声明合并详解一
  • 网站后台登录域名注册公司需要注册资金吗
  • 蓝牙钥匙技术详解:从基础原理到未来趋势 大纲
  • 基于SVM与HOG特征的交通标志检测与识别