返回顶部
首页 > 资讯 > 精选 >钉钉小程序web-view怎么内嵌H5页面并实现通信
  • 926
分享到

钉钉小程序web-view怎么内嵌H5页面并实现通信

2023-06-30 15:06:09 926人浏览 独家记忆
摘要

这篇文章主要介绍了钉钉小程序WEB-view怎么内嵌H5页面并实现通信的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇钉钉小程序web-view怎么内嵌H5页面并实现通信文章都会有所收获,下面我们一起来看看吧。1

这篇文章主要介绍了钉钉小程序WEB-view怎么内嵌H5页面并实现通信的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇钉钉小程序web-view怎么内嵌H5页面并实现通信文章都会有所收获,下面我们一起来看看吧。

1.引入页面

在管理端新建页面,同时在钉钉页面使用web-view引入,需要后端配合传入合适的token。

  • 钉钉页面引入

<template><view class="">            <web-view id="web-view-1" :src="`Http://10.10.5.231:9529/myNetwork?x-token=${token}`"></web-view></view></template>

2.在H5页面向钉钉发送消息

H5页面使用dd.postMessage()进行消息发送,并使用 dd.navigateTo()进行页面的跳转。

<template>  <div>   <el-button @click="handleToDT" >返回并发送消息</el-button>  </div></template><script>export default {  data() {    return {    }  },  created() {    var userAgent = navigator.userAgent    if (userAgent.indexOf('AlipayClient') > -1) {      // 支付宝小程序的 js-SDK 防止 404 需要动态加载,如果不需要兼容支付宝小程序,则无需引用此 JS 文件。      document.writeln('<script src="https://appx/web-view.min.js"' + '>' + '<' + '/' + 'script>')    },      methods: {        handleToDT() {              // 网页向小程序 postMessage 消息              dd.postMessage({ name: '测试web-view' })              setTimeout(()=>{                dd.navigateTo({ url: '/pages/index/myNetwork/index' })              },500)        },    }  },  </script>

钉钉页面使用@message进行消息的接受,但很坑的是,文档上接收方法为onMessage,但uniapp中需要改为@message才能接收到消息。

钉钉小程序web-view怎么内嵌H5页面并实现通信

<template><view class=""><web-view id="web-view-1" :src="`http://10.10.5.231:9529/myNetwork?x-token=${token}`" @message="test"></web-view></view></template><script>export default {data() {return {webViewContext: '',token: uni.getStorageSync('x-token')}},onLoad(e){      },methods: {test(e){console.log(e)}},                }</script><style></style>

3.在钉钉页面向H5发送消息,继而实现双向通信

钉钉页面创建实例,并调用this.webViewContext.postMessage()方法发送消息

<template><view class=""><web-view id="web-view-1" :src="`http://10.10.5.231:9529/myNetwork?x-token=${token}`" @message="test"></web-view></view></template><script>export default {data() {return {webViewContext: '',token: uni.getStorageSync('x-token')}},onLoad(e){    this.webViewContext = dd.createWebViewContext('web-view-1');      },methods: {test(e){this.webViewContext.postMessage({'sendToWebView': '1'});}},                }</script><style></style>

H5页面在mounted中使用dd.onMessage接收消息

  mounted() {    // 接收来自小程序的消息。    dd.onMessage = function(e) {      console.log(e); //{'sendToWebView': '1'}    }  },

4.注意 内容调试方式

钉钉页面在控制台查看数据即可 H5数据调试控制台开启方式

钉钉小程序web-view怎么内嵌H5页面并实现通信

钉钉小程序web-view怎么内嵌H5页面并实现通信

5.附双向通信全部代码

钉钉页面(即uniapp编写页面)

<template><view class=""><web-view id="web-view-1" :src="`http://10.10.5.231:9529/myNetwork?x-token=${token}`" @message="test"></web-view></view></template><script>export default {data() {return {webViewContext: '',token: uni.getStorageSync('x-token')}},onLoad(e){    this.webViewContext = dd.createWebViewContext('web-view-1');      },methods: {test(e){console.log(e)this.webViewContext.postMessage({'sendToWebView': '1'});}},                }</script><style></style>

H5页面(即挂载到管理端页面)

<template>  <div>      <el-button @click="handleToDT" >返回并发送消息</el-button>  </div></template><script>export default {  data() {    return {    }  },  created() {    var userAgent = navigator.userAgent    if (userAgent.indexOf('AlipayClient') > -1) {      // 支付宝小程序的 JS-SDK 防止 404 需要动态加载,如果不需要兼容支付宝小程序,则无需引用此 JS 文件。      document.writeln('<script src="https://appx/web-view.min.js"' + '>' + '<' + '/' + 'script>')    }  },  mounted() {    // 接收来自小程序的消息。    dd.onMessage = function(e) {      console.log(e); //{'sendToWebView': '1'}    }  },  methods: {    handleToDT() {      // javascript      // 网页向小程序 postMessage 消息      dd.postMessage({ name: '测试web-view' })      setTimeout(()=>{        dd.navigateTo({ url: '/pages/index/myNetwork/index' })      },500)    },      }}</script><style lang="sCSS" scoped></style>

关于“钉钉小程序web-view怎么内嵌H5页面并实现通信”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“钉钉小程序web-view怎么内嵌H5页面并实现通信”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网精选频道。

--结束END--

本文标题: 钉钉小程序web-view怎么内嵌H5页面并实现通信

本文链接: https://lsjlt.com/news/329779.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作