Uniapp中嵌入H5并在H5中跳轉(zhuǎn)到APP的指定頁(yè)面方法詳解
場(chǎng)景
有一個(gè)需求是,在app中嵌入一個(gè)H5頁(yè)面,H5是一個(gè)網(wǎng)絡(luò)頁(yè)面,不在app項(xiàng)目里,APP可以打開H5頁(yè)面,實(shí)現(xiàn)單點(diǎn)登錄,并且在H5 頁(yè)面中打開APP指定的頁(yè)面
Web-View
在uniapp中,有一個(gè)web-view組件,這就相當(dāng)于一個(gè)瀏覽器組件,可以用來承載網(wǎng)頁(yè)的容器,會(huì)自動(dòng)鋪滿整個(gè)頁(yè)面web-view的詳細(xì)文檔參考uniapp官網(wǎng)
https://uniapp.dcloud.net.cn/component/web-view.html#web-view
在官網(wǎng)中提供的是APP嵌入原生的H5頁(yè)面
從官方demo的代碼,原生H5頁(yè)面使用的HTML
在APP中使用web-view嵌入H5頁(yè)面使用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,在這里為了方便測(cè)試,使用官方的 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)頁(yè)</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)至其它頁(yè)面。</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è)向應(yīng)用發(fā)送消息,注意:小程序端應(yīng)用會(huì)在此頁(yè)面后退時(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)加載,如果不需要兼容支付寶小程序,則無(wú)需引用此 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 如果不需要兼容微信小程序,則無(wú)需引用此 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 如果不需要兼容頭條小程序,則無(wú)需引用此 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 如果不需要兼容百度小程序,則無(wú)需引用此 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 的頁(yè)面的關(guān)鍵方法 uni.reLaunch
uni.reLaunch({ url: '/pages/tabBar/component/component' });
這個(gè)方法是跳轉(zhuǎn)到APP的指定頁(yè)面,url就是APP頁(yè)面的路徑,在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頁(yè)面跳轉(zhuǎn)回APP的問題,但是使用uniapp開發(fā)H5就會(huì)失效,在uniapp開發(fā)H5頁(yè)面使用 uni.reLaunch 只能跳轉(zhuǎn)到H5項(xiàng)目本地的頁(yè)面。
解決方法如下
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
總結(jié)
到此這篇關(guān)于Uniapp中嵌入H5并在H5中跳轉(zhuǎn)到APP的指定頁(yè)面的文章就介紹到這了,更多相關(guān)Uniapp嵌入H5并跳轉(zhuǎn)到APP內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
js實(shí)現(xiàn)數(shù)組內(nèi)數(shù)據(jù)的上移和下移的實(shí)例
下面小編就為大家?guī)硪黄猨s實(shí)現(xiàn)數(shù)組內(nèi)數(shù)據(jù)的上移和下移的實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-11-11淺談webpack構(gòu)建工具配置和常用插件總結(jié)
這篇文章主要介紹了淺談webpack構(gòu)建工具配置和常用插件總結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2020-05-05微信小程序網(wǎng)絡(luò)請(qǐng)求模塊封裝的具體實(shí)現(xiàn)
大家做小程序項(xiàng)目的時(shí)候肯定會(huì)遇到數(shù)據(jù)對(duì)接需求,下面這篇文章主要給大家介紹了關(guān)于微信小程序網(wǎng)絡(luò)請(qǐng)求模塊封裝的具體實(shí)現(xiàn),文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-03-03JavaScript對(duì)象和字串之間的轉(zhuǎn)換實(shí)例探討
從對(duì)象的格式可以看出,如果字串的格式定義成 json 格式的, 就可以直接轉(zhuǎn)換為obj了,感興趣的朋友可以參考下哈2013-04-04Bootstrap項(xiàng)目實(shí)戰(zhàn)之子欄目資訊內(nèi)容
Bootstrap項(xiàng)目實(shí)戰(zhàn)之資訊內(nèi)容,本文主要學(xué)習(xí)制作一下子欄目資訊內(nèi)容,感興趣的小伙伴們可以參考一下2016-04-04js時(shí)間戳和c#時(shí)間戳互轉(zhuǎn)方法(推薦)
下面小編就為大家?guī)硪黄猨s時(shí)間戳和c#時(shí)間戳互轉(zhuǎn)方法(推薦)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02Input文本框隨著輸入內(nèi)容多少自動(dòng)延伸的實(shí)現(xiàn)
下面小編就為大家?guī)硪黄狪nput文本框隨著輸入內(nèi)容多少自動(dòng)延伸的實(shí)現(xiàn)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02微信小程序?qū)崿F(xiàn)實(shí)時(shí)圓形進(jìn)度條的方法示例
這篇文章主要給大家介紹了利用微信小程序?qū)崿F(xiàn)實(shí)時(shí)圓形進(jìn)度條的方法,文中給出了詳細(xì)的示例代碼,相信對(duì)大家具有一定的參考價(jià)值,需要的朋友們下面來一起看看吧。2017-02-02