uniappuniapp的App端web-view加载本地html

uniapp的App使用web-view加载html

  • 踩坑一,调试的时候H5能渲染页面可以调用部分uni api
    • 还有一个问题就是H5没有里的web-view不能收到消息的问题
    • web-view页面

踩坑一,调试的时候H5能渲染页面可以调用部分uni api

文章最后有代码

调试的时候H5能渲染,能调用部分api但是不能收到H5传过来的消息。
错误示范
这里有个问题,就是当真机调试的时候uni api就会失效,查找官网
后来放在这个目录下生效了
这个也有问题
这样app端就可以渲染了,也可以接收到html , postmessage消息了,但是H5端又渲染失败了,所以我又将页面渲染的时候分开渲染
这样就解决了

还有一个问题就是H5没有里的web-view不能收到消息的问题

虽然可以H5可以调用部分uni api但是无法给外部发送消息,这里查找了一个方法
这两种方法都可以实现向H5发送消息

接收页面需要条件编译一下就可以了
methods里的方法试用App
methods里的方法试用App,onLoad里监听H5发来的消息
官方的代码粘贴过来的进行了本地修改

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
    <title>网络网页</title>
    <style type="text/css">
      .btn {
        display: block;
        margin: 20px auto;
        padding: 5px;
        background-color: #007aff;
        border: 0;
        color: #ffffff;
        height: 40px;
        width: 200px;
      }

      .btn-red {
        background-color: #dd524d;
      }

      .btn-yellow {
        background-color: #f0ad4e;
      }

      .desc {
        padding: 10px;
        color: #999999;
      }

      .post-message-section {
        visibility: hidden;
      }
    </style>
  </head>
  <body>
    <p class="desc">web-view 组件加载网络 html 示例。点击下列按钮,跳转至其它页面。</p>
    <div class="btn-list">
      <button class="btn" type="button" data-action="navigateTo">navigateTo</button>
      <button class="btn" type="button" data-action="redirectTo">redirectTo</button>
      <button class="btn" type="button" data-action="navigateBack">navigateBack</button>
      <button class="btn" type="button" data-action="reLaunch">reLaunch</button>
      <button class="btn" type="button" data-action="switchTab">switchTab</button>
    </div>
    <div class="post-message-section">
      <p class="desc">网页向应用发送消息,注意:小程序端应用会在此页面后退时接收到消息。</p>
      <div class="btn-list">
        <button class="btn btn-red" type="button" id="postMessage">postMessage</button>
      </div>
    </div>
    <script type="text/javascript">
      var userAgent = navigator.userAgent;
      if (userAgent.indexOf('AlipayClient') > -1) {
        // 支付宝小程序的 JS-SDK 防止 404 需要动态加载,如果不需要兼容支付宝小程序,则无需引用此 JS 文件。
        document.writeln('<script src="//i2.wp.com/appx/web-view.min.js"' + '>' + '<' + '/' + 'script>');
      } else if (/QQ/i.test(userAgent) && /miniProgram/i.test(userAgent)) {
        // QQ 小程序
        document.write(
          '<script type="text/javascript" src="//i2.wp.com/qqq.gtimg.cn/miniprogram/webview_jssdk/qqjssdk-1.0.0.js"></script>'
        );
      } else if (/miniProgram/i.test(userAgent) && /micromessenger/i.test(userAgent)) {
        // 微信小程序 JS-SDK 如果不需要兼容微信小程序,则无需引用此 JS 文件。
        document.write('<script type="text/javascript" src="//i2.wp.com/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="//i2.wp.com/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="//i2.wp.com/b.bdstatic.com/searchbox/icms/searchbox/js/swan-2.0.18.js"></script>'
        );
      } else if (/quickapp/i.test(userAgent)) {
        // quickapp
        document.write('<script type="text/javascript" src="//i2.wp.com/quickapp/jssdk.webview.min.js"></script>');
      }
      if (!/toutiaomicroapp/i.test(userAgent)) {
        document.querySelector('.post-message-section').style.visibility = 'visible';
      }
    </script>
    <!-- uni 的 SDK -->
    <!-- 需要把 uni.webview.1.5.5.js 下载到自己的服务器 -->
    <script type="text/javascript" src="./js/uni-webview-js.js"></script>
    <!-- <script type="text/javascript" src="//i2.wp.com/js.cdn.aliyun.dcloud.net.cn/dev/uni-app/uni.webview.1.5.2.js"></script> -->
    <script type="text/javascript">
      // 待触发 `UniAppJSBridgeReady` 事件后,即可调用 uni 的 API。
      document.addEventListener('UniAppJSBridgeReady', function() {
        uni.postMessage({
            data: {
                action: 'message'
            }
        });
        uni.getEnv(function(res) {
            console.log('当前环境:' + JSON.stringify(res));
        });

        document.querySelector('.btn-list').addEventListener('click', function(evt) {
          var target = evt.target;
          if (target.tagName === 'BUTTON') {
            var action = target.getAttribute('data-action');
            switch (action) {
              case 'switchTab':
                uni.switchTab({
                  url: '/pages/tabBar/API/API'
                });
                break;
              case 'reLaunch':
                uni.reLaunch({
                  url: '/pages/tabBar/component/component'
                });
                break;
              case 'navigateBack':
                uni.navigateBack({
                  delta: 1
                });
                break;
              default:
                uni[action]({
                  url: '/pages/component/button/button'
                });
                break;
            }
          }
        });
        document.getElementById('postMessage').addEventListener('click', function() {
        window.parent.postMessage('子页面发送的消息1','http://localhost:8080')
		  uni.postMessage({
            data: {
              action: 'message1111'
            }
          });
        });
      });
    </script>
  </body>
</html>


web-view页面

<template>
	<view>
		<web-view :src="src" 
		@message='message'
		@onPostMessage='message'
		></web-view>
	</view>
</template>

<script>
	export default {
		data() {
			return {
				// #ifdef APP-PLUS
				src:'/hybrid/html/web-view.html',
				// #endif
				// #ifdef H5
				src:'/static/html/web-view.html',
				// #endif
			}
		},
		onLoad() {
			//  #ifdef H5
			window.addEventListener("message", e => {
			       console.log(e.origin) //子页面URL,这里是http://b.index.com
			              console.log(e.source) // 子页面window对象,全等于iframe.contentWindow
			              console.log(e.data) //子页面发送的消息
			    }, false)
			// #endif
			
		},
		methods: {
			message(e){
				console.log('来自网页',e);
			}
		}
	}
</script>

<style>

</style>