如何在uniapp項目中嵌套H5 頁面
如何在 uniapp項目中 嵌套h5頁面
在UniApp中可以通過使用 web-view 組件來嵌入H5頁面。
首先需要安裝uni-app的依賴包,然后創(chuàng)建一個新的頁面(比如名為"WebPage.vue")作為容器頁面,并將其放置于pages目錄下。
接下來,在該頁面的template部分添加web-view組件,設置src屬性為所需嵌入的H5頁面地址,示例如下:
<template>
<view class="container">
<!-- web-view組件 -->
<web-view :src="url"></web-view>
</view>
</template>在script部分定義data數(shù)據(jù)對象,并初始化url變量為所需嵌入的H5頁面地址,示例如下:
<script>
export default {
data() {
return {
url: 'https://www.example.com' // H5頁面地址
}
},
}
</script>最后,在manifest.json文件中注冊這個頁面,確保能正常打開。
完成上述操作后,就可以運行項目查看效果了。當點擊進入到WebPage頁面時,會自動加載指定的H5頁面內(nèi)容。
web-view 是一個 web 瀏覽器組件,可以用來承載網(wǎng)頁的容器,會自動鋪滿整個頁面(nvue 使用需要手動指定寬高)。
各小程序平臺,web-view 加載的 url 需要在后臺配置域名白名單,包括內(nèi)部再次 iframe 內(nèi)嵌的其他 url 。
擴展:
如何Uniapp中嵌入H5,并且在H5中跳轉到APP的指定頁面
場景
有一個需求是,在app中嵌入一個H5頁面,H5是一個網(wǎng)絡頁面,不在app項目里,APP可以打開H5頁面,實現(xiàn)單點登錄,并且在H5 頁面中打開APP指定的頁面
Web-View
在uniapp中,有一個web-view組件,這就相當于一個瀏覽器組件,可以用來承載網(wǎng)頁的容器,會自動鋪滿整個頁面
web-view的詳細文檔參考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組件就可以實現(xiàn),代碼如下
<template> <view> <web-view src="https://uniapp.dcloud.io/static/web-view.html"></web-view> </view> </template>
src是H5的地址,可以是任何網(wǎng)址,與APP的地址什么的沒有關系,也可以是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)絡網(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)絡 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">網(wǎng)頁向應用發(fā)送消息,注意:小程序端應用會在此頁面后退時接收到消息。</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 需要動態(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 下載到自己的服務器 -->
<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('當前環(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>在這里我們提取出關鍵的代碼
<!-- 需要把 uni.webview.1.5.4.js 下載到自己的服務器 --> 導入web-view 的SDK
<script type="text/javascript" src="https://unpkg.com/@dcloudio/uni-webview-js@0.0.3/index.js"></script>調(diào)用方法跳轉至app 的頁面的關鍵方法 uni.reLaunch
uni.reLaunch({
url: '/pages/tabBar/component/component'
});這個方法是跳轉到APP的指定頁面,url就是APP頁面的路徑,在APP項目中目錄結構如下

對于這幾個跳轉方法可以自己去學習
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頁面跳轉回APP的問題,但是使用uniapp開發(fā)H5就會失效,在uniapp開發(fā)H5頁面使用 uni.reLaunch 只能跳轉到H5項目本地的頁面。 解決方法如下 1. 下載官網(wǎng)web-view的SDK

在官網(wǎng)的原生H5 demo 導入了這個關鍵的Js文件,通過瀏覽器打開
https://unpkg.com/@dcloudio/uni-webview-js@0.0.3/index.js

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

2. 在H5項目的main.js 文件里導入這個文件

3. 原生H5使用的跳轉方法和uniapp開發(fā)的H5使用的跳轉方法是不一樣的
uni.webView.reLaunch({
url: '/pages/tabBar/component/component'
});區(qū)別在于 uniapp開發(fā)的H5要加上 webView
到此這篇關于如何在uniapp項目中嵌套H5 頁面的文章就介紹到這了,更多相關uniapp 嵌套H5 頁面內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
JavaScript實現(xiàn)漢字轉換為拼音及縮寫的方法示例
這篇文章主要介紹了JavaScript實現(xiàn)漢字轉換為拼音及縮寫的方法,結合實例形式分析了javascript數(shù)組遍歷、轉換實現(xiàn)漢字轉拼音相關操作技巧,需要的朋友可以參考下2019-03-03
JavaScript人臉識別技術及臉部識別JavaScript類庫Tracking.js
人臉識別的JavaScript程序包是Face Detection,它是由Jay Salvat和Liu Liu開發(fā)的。它是一個標準的jQuery插件,通過對提供的圖片進行分析,返回所有找到的臉部圖像的坐標,感興趣的朋友跟著小編一起學習js人臉識別技術及臉部識別JavaScript類庫Tracking.js吧2015-09-09
JavaScript給每一個li節(jié)點綁定點擊事件的實現(xiàn)方法
這篇文章主要介紹了JavaScript給每一個li節(jié)點綁定點擊事件的實現(xiàn)方法,包括js循環(huán)給li綁定參數(shù)不同的點擊事件,需要的朋友可以參考下2016-12-12
微信小程序 JS動態(tài)修改樣式的實現(xiàn)方法
這篇文章主要給大家介紹了關于微信小程序JS動態(tài)修改樣式的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-12-12
Javascript怎樣使用SessionStorage和LocalStorage
這篇文章主要介紹了Javascript怎樣使用SessionStorage和LocalStorage,對web存儲數(shù)據(jù)感興趣的同學,可以參考下2021-04-04

