uni-app打開外部鏈接方式總結(jié)(h5和app)
問題描述
在應(yīng)用中打開一個(gè)外部的html頁面,即完整http鏈接的頁面。h5通過window.open或是內(nèi)嵌iframe基本都沒有問題,本文主要針對(duì)app端的方法進(jìn)行匯總,不涉及到小程序端。
方案1
使用uni-app的擴(kuò)展組件 uni-link,使用參考文檔uni-app官網(wǎng)
該組件的行為是在app內(nèi)打開外部瀏覽器,在h5打開新網(wǎng)頁。
方案2
方案1app端打開外部瀏覽器,在使用體驗(yàn)上會(huì)有一種割裂感
查看uni-link的源碼,發(fā)現(xiàn)app端調(diào)用的是plus.runtime.openURL方法,
可以在這個(gè)基礎(chǔ)上進(jìn)行優(yōu)化,使用plus.runtime.openWeb替代app打開,這個(gè)方法會(huì)新開內(nèi)置窗口打開頁面,而且自帶標(biāo)題欄和返回,安卓端的隱私協(xié)議文件(androidPrivacy.json)的內(nèi)容中a標(biāo)簽調(diào)用的即是這個(gè)方法
void plus.runtime.openWeb(url);
參數(shù):url: ( String ) 必選 要打開的URL地址 ,僅支持http/https地址
注意標(biāo)題會(huì)讀取載入html的title屬性,如果沒有的話標(biāo)題顯示為空
方案3
使用app-plus的webview模塊api進(jìn)行管理,
plus.webview.open( url, id, styles, aniShow, duration, showedCB )或是plus.webview.create( url, id, styles, extras );
這兩個(gè)方法都支持通過style屬性控制標(biāo)題欄的樣式,如果不設(shè)置標(biāo)題文字,則讀取加載的html的title屬性,具體參數(shù)支持比較多,參考文檔??????????????HTML5+ API Reference
const wv = plus.webview.open(query.src, 'webview', { titleNView: { autoBackButton: true, titleColor: '#fff', backgroundColor: '#0045c4', titleAlign: 'center', }, }) // wv.show()
該方案存在問題是返回操作在ios和安卓上不太一致,還可能會(huì)清除uni-app的頁面路由管理???????,不建議使用
方案4
使用uni-app的webview組件進(jìn)行加載,及新建一個(gè)路由頁面,/pages/webview,內(nèi)容只放一個(gè)webview
<template> <view v-if="src"> <!-- #ifdef H5 --> <iframe width="100%" height="100%" :src="src" :title="title" /> <!-- #endif --> <!-- #ifndef H5 --> <web-view :webview-styles="wbStyles" :src="src" :fullscreen="false" /> <!-- #endif --> </view> </template> <script> export default { data() { return { title: '', src: '', wbStyles: { width: '100%', height: '100%', }, } }, onLoad(option) { this.title = option?.title this.src = option?.src }, } </script>
webview組件在h5中也是使用iframe實(shí)現(xiàn),但是dom嵌套層級(jí)太多,不方便控制寬高,所以這里就直接按條件編譯,在h5中用iframe。uni-app官方也是推薦h5中使用iframe。
app的標(biāo)題欄需要通過pages.json來控制,如下參考,具體文檔見???????uni-app官網(wǎng)
{ "path": "webview/index", "style": { "app-plus": { "titleNView": { "backgroundColor": "#0045c4", "titleAlign": "center", "titleSize": "16px", "backButton": { "fontSize": "20px", "fontWeight": "bold" } } } } }
這里titleNView的設(shè)置和方案3api的參數(shù)基本一致
總結(jié)
到此這篇關(guān)于uni-app打開外部鏈接方式(h5和app)的文章就介紹到這了,更多相關(guān)uni-app打開外部鏈接內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript通過使用onerror設(shè)置默認(rèn)圖像顯示代替alt
這篇文章主要介紹了JavaScript通過使用onerror設(shè)置默認(rèn)圖像顯示代替alt的相關(guān)資料,需要的朋友可以參考下2016-03-03微信公眾號(hào)錄音文件的播放與保存(amr文件轉(zhuǎn)mp3)
本文主要介紹了微信公眾號(hào)錄音文件的播放與保存(amr文件轉(zhuǎn)mp3),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08基于JS實(shí)現(xiàn)EOS隱藏錯(cuò)誤提示層代碼
本文給大家分享一段代碼基于js實(shí)現(xiàn)EOS隱藏錯(cuò)誤提示層,對(duì)eos隱藏提示層的相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2016-04-04JS使用Chrome瀏覽器實(shí)現(xiàn)調(diào)試線上代碼
這篇文章主要介紹了JS使用Chrome瀏覽器實(shí)現(xiàn)調(diào)試線上代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07基于JavaScript實(shí)現(xiàn)Json數(shù)據(jù)根據(jù)某個(gè)字段進(jìn)行排序
這篇文章主要介紹了基于JavaScript實(shí)現(xiàn)Json數(shù)據(jù)根據(jù)某個(gè)字段進(jìn)行排序的相關(guān)資料,需要的朋友可以參考下2015-11-11JavaScript實(shí)現(xiàn)復(fù)制文本到剪切板功能的方法小結(jié)
這篇文章給大家介紹了三種JavaScript實(shí)現(xiàn)復(fù)制文本到剪切板的方法,Clipboard API,document.execCommand以及useClipboard這三個(gè)接口,文章通過代碼示例給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-11-11js實(shí)現(xiàn)鼠標(biāo)滑過文字鏈接色彩變化的效果
這篇文章主要介紹了js實(shí)現(xiàn)鼠標(biāo)滑過文字鏈接色彩變化的效果,涉及javascript鼠標(biāo)事件及樣式操作的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-05-05JS實(shí)現(xiàn)數(shù)組扁平化的方法分享
數(shù)組扁平化指的是:將一個(gè)多層嵌套的數(shù)組,處理成只有一層的數(shù)組。本文主要和大家介紹了幾個(gè)常用的JS數(shù)組扁平化方法,希望對(duì)大家有所幫助2023-04-04