webview.html 4.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. <!DOCTYPE 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">navigateTo</button>
  37. <button class="btn" type="button" data-action="redirectTo">redirectTo</button>
  38. <button class="btn" type="button" data-action="navigateBack">navigateBack</button>
  39. <button class="btn" type="button" data-action="reLaunch">reLaunch</button>
  40. <button class="btn" type="button" data-action="switchTab">switchTab</button>
  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">postMessage</button>
  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('<script src="https://appx/web-view.min.js"' + '>' + '<' + '/' + 'script>');
  53. } else if (/QQ/i.test(userAgent) && /miniProgram/i.test(userAgent)) {
  54. // QQ 小程序
  55. document.write(
  56. '<script type="text/javascript" src="https://qqq.gtimg.cn/miniprogram/webview_jssdk/qqjssdk-1.0.0.js"><\/script>'
  57. );
  58. } else if (/miniProgram/i.test(userAgent) && /micromessenger/i.test(userAgent)) {
  59. // 微信小程序 JS-SDK 如果不需要兼容微信小程序,则无需引用此 JS 文件。
  60. document.write('<script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.4.0.js"><\/script>');
  61. } else if (/toutiaomicroapp/i.test(userAgent)) {
  62. // 头条小程序 JS-SDK 如果不需要兼容头条小程序,则无需引用此 JS 文件。
  63. document.write(
  64. '<script type="text/javascript" src="https://s3.pstatp.com/toutiao/tmajssdk/jssdk-1.0.1.js"><\/script>');
  65. } else if (/swan/i.test(userAgent)) {
  66. // 百度小程序 JS-SDK 如果不需要兼容百度小程序,则无需引用此 JS 文件。
  67. document.write(
  68. '<script type="text/javascript" src="https://b.bdstatic.com/searchbox/icms/searchbox/js/swan-2.0.18.js"><\/script>'
  69. );
  70. } else if (/quickapp/i.test(userAgent)) {
  71. // quickapp
  72. document.write('<script type="text/javascript" src="https://quickapp/jssdk.webview.min.js"><\/script>');
  73. }
  74. if (!/toutiaomicroapp/i.test(userAgent)) {
  75. // document.querySelector('.post-message-section').style.visibility = 'visible';
  76. }
  77. </script>
  78. <!-- uni 的 SDK -->
  79. <!-- 需要把 uni.webview.1.5.4.js 下载到自己的服务器 -->
  80. <script type="text/javascript" src="./js/uni-webview.js"></script>
  81. <script type="text/javascript">
  82. // 待触发 `UniAppJSBridgeReady` 事件后,即可调用 uni 的 API。
  83. document.addEventListener('UniAppJSBridgeReady', function() {
  84. uni.postMessage({
  85. data: {
  86. "webviewMessage": "webviewClose"
  87. }
  88. });
  89. uni.getEnv(function(res) {
  90. });
  91. });
  92. </script>
  93. </body>
  94. </html>