当前位置:   article > 正文

小程序webView 实现小程序内嵌H5页面_小程序 webview

小程序 webview

web-view | 微信开放文档

本案例新建了一个 webView页面  只渲染webView组件

配置路由,跳转页面的时候 前缀使用‘/subPages/webView/index?weburl=https://xxxxx’

componentDidMount 的时候 获取路由中的 weburl 地址参数

  1. async componentDidMount() {
  2. const router = getCurrentInstance().router;
  3. const params = router.params;
  4. let url = params.weburl;
  5. // 对url进行参数处理 ,可以增加需要传递给H5的token等其他参数
  6. this.setState({
  7. url: url, // 获取其他小程序页面 请求跳转的地址
  8. });
  9. }
  10. render() {
  11. const { url } = this.state;
  12. return (
  13. <WebView
  14. src={decodeURIComponent(url)} // H5地址 加上域名的全链路地址
  15. onMessage={(res) => {
  16. this.setPostMessage(res.detail.data); // 存储H5传回来的数据 可以存到公共区域 方便使用
  17. }}
  18. />
  19. );
  20. }

发起跳转的方式:

  1. const token=''; // 自行获取token
  2. const weburl='' ;// 自行定义地址
  3. Taro.navigateTo({
  4. url: `/subPages/webView/index?weburl=${weburl}&token=${token}` ,
  5. });

上面是跳转到小程序的webview.jsx页面  并且带上了需要跳转的H5地址weburl

在webview页面加载的时候获取H5地址 并添加在web-view标签上 

如果页面中很多地方需要跳转H5页面 并且H5页面是基本固定的域名 可以将Taro.navigateTo进行封装处理

案例:

  1. const toWebFun = (type = 'navigateTo') => {
  2. return function (url, isRequireToken) {
  3. const params = queryToObj(url); //
  4. const token = Taro.getStorageSync(ConstantList.TOKEN); //
  5. const host = Config.HOST_H5; // H5固定域名
  6. const TaroNavigate = type === 'redirectTo' ? Taro.redirectTo : Taro.navigateTo;
  7. let path = '';
  8. let tokenKey = '?token=';
  9. let ismini = '?ismini=1'; // 个人定义代表小程序内打开H5 方便区分
  10. // 带有https链接情况 就不使用host固定域名
  11. if (url.includes('https://')) {
  12. path = `/subPages/webView/index?weburl=${encodeURIComponent(
  13. `${url}${url.indexOf('?') > -1 ? '&token=' : '?token='}${token}&ismini=1`,
  14. )}`;
  15. TaroNavigate({
  16. url: path,
  17. });
  18. return;
  19. }
  20. // 如果连接本身带有?后面参数 则不要覆盖 而是追加
  21. if (url.indexOf('?') !== -1) {
  22. tokenKey = '&token=';
  23. ismini = '&ismini=1';
  24. }
  25. if (isRequireToken) { // 是否需要登录的页面
  26. if (token) {
  27. path = `/subPages/webView/index?weburl=${encodeURIComponent(`${host}#${url + tokenKey + token}${ismini}`)} `;
  28. } else {
  29. // 需要登录 有没有token的情况 先跳转登录 然后 带上url登陆后继续执行跳转操作 又会继续执行toWebFun 函数
  30. Taro.navigateTo({
  31. url: `/subPages/login/index?redirectTo=${url}`,
  32. });
  33. return;
  34. }
  35. } else {
  36. // 无需token
  37. path = `/subPages/webView/index?weburl=${encodeURIComponent(`${host}#${url}${ismini}`)}`;
  38. }
  39. TaroNavigate({
  40. url: path,
  41. });
  42. };
  43. };
  44. export const navigateToWeb = toWebFun();

在其他页面就是使用navigateToWeb 跳转H5页面

H5页面中提供一下方法回到小程序页面及给小程序页面传值

小程序和网页之间的通信是单向的,即只能从网页发送消息到小程序,不能从小程序发送消息到网页。

  1. // H5与小程序交互的方式
  2. // 返回小程序首页
  3. wx.miniProgram.navigateTo({url: '/pages/home/index'})
  4. // 给小程序传递参数
  5. wx.miniProgram.postMessage({ data: 'foo' })
  6. // 给小程序传递复杂参数
  7. wx.miniProgram.postMessage({ data: {foo: 'bar'} })
  8. // 小程序web-view 存储H5传回来的数据
  9. // onMessage={(res) => {
  10. // this.setPostMessage(res.detail.data); // 存储H5传回来的数据
  11. // }}
  12. // 获取当前环境
  13. wx.miniProgram.getEnv(function(res) { console.log(res.miniprogram) })
  14. // 小程序下的H5 去小程序的虚拟订单页
  15. wx.miniProgram.navigateTo({url:`/subPages/virtualOrderList/virtualOrderList?type=coupon`});

小程序可以在跳转之前在url携带一些参数,

或者直接通过后端缓存的方式 在小程序存储缓存换取缓存id,拼接在url上,跳转到H5之后通过缓存id获取缓存数据

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号