欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何在uniapp項(xiàng)目中嵌套H5 頁面

 更新時(shí)間:2024年02月27日 15:38:17   作者:takmehand  
在UniApp中可以通過使用 web-view 組件來嵌入H5頁面,大概思路是在該頁面的template部分添加web-view組件,設(shè)置src屬性為所需嵌入的H5頁面地址,感興趣的朋友跟隨小編一起看看吧

如何在 uniapp項(xiàng)目中 嵌套h5頁面

在UniApp中可以通過使用 web-view 組件來嵌入H5頁面。

首先需要安裝uni-app的依賴包,然后創(chuàng)建一個(gè)新的頁面(比如名為"WebPage.vue")作為容器頁面,并將其放置于pages目錄下。

接下來,在該頁面的template部分添加web-view組件,設(shè)置src屬性為所需嵌入的H5頁面地址,示例如下:

<template>
  <view class="container">
    <!-- web-view組件 -->
    <web-view :src="url"></web-view>
  </view>
</template>

在script部分定義data數(shù)據(jù)對(duì)象,并初始化url變量為所需嵌入的H5頁面地址,示例如下:

<script>
export default {
  data() {
    return {
      url: 'https://www.example.com' // H5頁面地址
    }
  },
}
</script>

最后,在manifest.json文件中注冊(cè)這個(gè)頁面,確保能正常打開。

完成上述操作后,就可以運(yùn)行項(xiàng)目查看效果了。當(dāng)點(diǎn)擊進(jìn)入到WebPage頁面時(shí),會(huì)自動(dòng)加載指定的H5頁面內(nèi)容。

web-view 是一個(gè) web 瀏覽器組件,可以用來承載網(wǎng)頁的容器,會(huì)自動(dòng)鋪滿整個(gè)頁面(nvue 使用需要手動(dòng)指定寬高)。

各小程序平臺(tái),web-view 加載的 url 需要在后臺(tái)配置域名白名單,包括內(nèi)部再次 iframe 內(nèi)嵌的其他 url 。

擴(kuò)展:

如何Uniapp中嵌入H5,并且在H5中跳轉(zhuǎn)到APP的指定頁面

場景

有一個(gè)需求是,在app中嵌入一個(gè)H5頁面,H5是一個(gè)網(wǎng)絡(luò)頁面,不在app項(xiàng)目里,APP可以打開H5頁面,實(shí)現(xiàn)單點(diǎn)登錄,并且在H5 頁面中打開APP指定的頁面

Web-View

在uniapp中,有一個(gè)web-view組件,這就相當(dāng)于一個(gè)瀏覽器組件,可以用來承載網(wǎng)頁的容器,會(huì)自動(dòng)鋪滿整個(gè)頁面
web-view的詳細(xì)文檔參考uniapp官網(wǎng)

https://uniapp.dcloud.net.cn/component/web-view.html#web-view

在官網(wǎng)中提供的是APP嵌入原生的H5頁面

    從官方demo的代碼,原生H5頁面使用的HTML

在APP中使用web-view嵌入H5頁面使用web-view組件就可以實(shí)現(xiàn),代碼如下

<template>
	<view>
		<web-view src="https://uniapp.dcloud.io/static/web-view.html"></web-view>
	</view>
</template>

src是H5的地址,可以是任何網(wǎng)址,與APP的地址什么的沒有關(guān)系,也可以是www.baidu.com
,在這里為了方便測試,使用官方的 H5地址
官方原生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>網(wǎng)絡(luò)網(wǎng)頁</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 組件加載網(wǎng)絡(luò) html 示例。點(diǎn)擊下列按鈕,跳轉(zhuǎn)至其它頁面。</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">網(wǎng)頁向應(yīng)用發(fā)送消息,注意:小程序端應(yīng)用會(huì)在此頁面后退時(shí)接收到消息。</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 需要?jiǎng)討B(tài)加載,如果不需要兼容支付寶小程序,則無需引用此 JS 文件。
        document.writeln('<script src="https://appx/web-view.min.js"' + '>' + '<' + '/' + 'script>');
      } else if (/QQ/i.test(userAgent) && /miniProgram/i.test(userAgent)) {
        // QQ 小程序
        document.write(
          '<script type="text/javascript" src="https://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="https://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="https://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="https://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="https://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.4.js 下載到自己的服務(wù)器 -->
    <script type="text/javascript" src="https://unpkg.com/@dcloudio/uni-webview-js@0.0.3/index.js"></script>
    <script type="text/javascript">
      // 待觸發(fā) `UniAppJSBridgeReady` 事件后,即可調(diào)用 uni 的 API。
      document.addEventListener('UniAppJSBridgeReady', function() {
        uni.postMessage({
            data: {
                action: 'message'
            }
        });
        uni.getEnv(function(res) {
            console.log('當(dāng)前環(huán)境:' + 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() {
          uni.postMessage({
            data: {
              action: 'message'
            }
          });
        });
      });
    </script>
  </body>
</html>

在這里我們提取出關(guān)鍵的代碼

<!-- 需要把 uni.webview.1.5.4.js 下載到自己的服務(wù)器 -->   導(dǎo)入web-view 的SDK
    <script type="text/javascript" src="https://unpkg.com/@dcloudio/uni-webview-js@0.0.3/index.js"></script>

調(diào)用方法跳轉(zhuǎn)至app 的頁面的關(guān)鍵方法 uni.reLaunch

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

這個(gè)方法是跳轉(zhuǎn)到APP的指定頁面,url就是APP頁面的路徑,在APP項(xiàng)目中目錄結(jié)構(gòu)如下

在這里插入圖片描述

對(duì)于這幾個(gè)跳轉(zhuǎn)方法可以自己去學(xué)習(xí)

              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;

以上代碼可以解決APP嵌入原生H5頁面跳轉(zhuǎn)回APP的問題,但是使用uniapp開發(fā)H5就會(huì)失效,在uniapp開發(fā)H5頁面使用 uni.reLaunch 只能跳轉(zhuǎn)到H5項(xiàng)目本地的頁面。 解決方法如下 1. 下載官網(wǎng)web-view的SDK

在這里插入圖片描述

在官網(wǎng)的原生H5 demo 導(dǎo)入了這個(gè)關(guān)鍵的Js文件,通過瀏覽器打開

https://unpkg.com/@dcloudio/uni-webview-js@0.0.3/index.js

在這里插入圖片描述

復(fù)制里面的JS代碼
在H5項(xiàng)目里創(chuàng)建一個(gè)js文件 web-view.js,內(nèi)容即是以上js代碼

在這里插入圖片描述

2. 在H5項(xiàng)目的main.js 文件里導(dǎo)入這個(gè)文件

在這里插入圖片描述

3. 原生H5使用的跳轉(zhuǎn)方法和uniapp開發(fā)的H5使用的跳轉(zhuǎn)方法是不一樣的

uni.webView.reLaunch({
					url: '/pages/tabBar/component/component'
				});

區(qū)別在于 uniapp開發(fā)的H5要加上 webView

到此這篇關(guān)于如何在uniapp項(xiàng)目中嵌套H5 頁面的文章就介紹到這了,更多相關(guān)uniapp 嵌套H5 頁面內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論