• Uniapp中嵌入H5( uniapp开发的H5),并且在H5中跳转到APP的指定页面


    原生H5跳转uniapp开发的app方式:

    1.在APP中使用web-view嵌入H5页面使用web-view组件实现
    1. <template>
    2. <view>
    3. <web-view src="https://uniapp.dcloud.net.cn/component/web-view.html">web-view>
    4. view>
    5. template>

    2.在H5项目引入webview.js

    1. 导入web-view 的SDK

     3.调用方法跳转至app 内部的页面的关键方法 uni.reLaunch

    1. uni.reLaunch({
    2. url: '/pages/tabBar/component/component'
    3. });

    4.跳转方式:

    1. <script type="text/javascript" src="https://unpkg.com/@dcloudio/uni-webview-js@0.0.3/index.js">script>
    2. <script type="text/javascript">
    3. // 待触发 `UniAppJSBridgeReady` 事件后,即可调用 uni 的 API。
    4. H5端与app端通信
    5. document.addEventListener('UniAppJSBridgeReady', function() {
    6. uni.postMessage({
    7. data: {
    8. action: 'message'
    9. }
    10. });
    11. uni.getEnv(function(res) {
    12. console.log('当前环境:' + JSON.stringify(res));
    13. });
    14. document.querySelector('.btn-list').addEventListener('click', function(evt) {
    15. var target = evt.target;
    16. if (target.tagName === 'BUTTON') {
    17. var action = target.getAttribute('data-action');
    18. switch (action) {
    19. case 'switchTab':
    20. uni.switchTab({
    21. url: '/pages/tabBar/API/API'
    22. });
    23. break;
    24. case 'reLaunch':
    25. uni.reLaunch({
    26. url: '/pages/tabBar/component/component'
    27. });
    28. break;
    29. case 'navigateBack':
    30. uni.navigateBack({
    31. delta: 1
    32. });
    33. break;
    34. default:
    35. uni[action]({
    36. url: '/pages/component/button/button'
    37. });
    38. break;
    39. }
    40. }
    41. });
    42. document.getElementById('postMessage').addEventListener('click', function() {
    43. uni.postMessage({
    44. data: {
    45. action: 'message'
    46. }
    47. });
    48. });
    49. });
    50. script>

    上面的跳转方式可以解决APP嵌入原生H5页面跳转回APP的问题,但是使用uniapp开发的H5就会失效,在uniapp开发H5页面使用 uni.reLaunch 只能跳转到H5项目本地的页面。

    uniapp开发H5跳转方式:

    1.在H5项目里引入 web-view.js:

    通过官网链接下载 web-view.js文件(下载链接,打开链接右键另存为下载链接,),放到项目的static/js文件中

    2.在main.js中引入

    1. import App from './App'
    2. import webView from './static/js/uni.webview.1.5.2.js'
    3. ....

    3.使用方式:

    1. // #ifdef APP-PLUS
    2. uni.webView.postMessage({
    3. data: {
    4. action: 'uni-app',
    5. }
    6. });
    7. uni.webView.reLaunch({
    8. url: '/pages/tabBar/component/component'
    9. });

    区别在于 uniapp开发的H5要在uni前面加上 webView

    官方H5代码:

    1. html>
    2. <html>
    3. <head>
    4. <meta charset="utf-8" />
    5. <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
    6. <title>网络网页title>
    7. <style type="text/css">
    8. .btn {
    9. display: block;
    10. margin: 20px auto;
    11. padding: 5px;
    12. background-color: #007aff;
    13. border: 0;
    14. color: #ffffff;
    15. height: 40px;
    16. width: 200px;
    17. }
    18. .btn-red {
    19. background-color: #dd524d;
    20. }
    21. .btn-yellow {
    22. background-color: #f0ad4e;
    23. }
    24. .desc {
    25. padding: 10px;
    26. color: #999999;
    27. }
    28. .post-message-section {
    29. visibility: hidden;
    30. }
    31. style>
    32. head>
    33. <body>
    34. <p class="desc">web-view 组件加载网络 html 示例。点击下列按钮,跳转至其它页面。p>
    35. <div class="btn-list">
    36. <button class="btn" type="button" data-action="navigateTo">navigateTobutton>
    37. <button class="btn" type="button" data-action="redirectTo">redirectTobutton>
    38. <button class="btn" type="button" data-action="navigateBack">navigateBackbutton>
    39. <button class="btn" type="button" data-action="reLaunch">reLaunchbutton>
    40. <button class="btn" type="button" data-action="switchTab">switchTabbutton>
    41. div>
    42. <div class="post-message-section">
    43. <p class="desc">网页向应用发送消息,注意:小程序端应用会在此页面后退时接收到消息。p>
    44. <div class="btn-list">
    45. <button class="btn btn-red" type="button" id="postMessage">postMessagebutton>
    46. div>
    47. div>
    48. <script type="text/javascript">
    49. var userAgent = navigator.userAgent;
    50. if (userAgent.indexOf('AlipayClient') > -1) {
    51. // 支付宝小程序的 JS-SDK 防止 404 需要动态加载,如果不需要兼容支付宝小程序,则无需引用此 JS 文件。
    52. document.writeln('