亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

uni-app打開外部鏈接方式總結(h5和app)

瀏覽:18日期:2022-06-01 15:52:17
目錄
  • 問題描述
  • 方案1
  • 方案2
  • 方案3
  • 方案4
  • 總結

問題描述

在應用中打開一個外部的html頁面,即完整http鏈接的頁面。h5通過window.open或是內嵌iframe基本都沒有問題,本文主要針對app端的方法進行匯總,不涉及到小程序端。

方案1

使用uni-app的擴展組件 uni-link,使用參考文檔uni-app官網

該組件的行為是在app內打開外部瀏覽器,在h5打開新網頁。

方案2

方案1app端打開外部瀏覽器,在使用體驗上會有一種割裂感

查看uni-link的源碼,發現app端調用的是plus.runtime.openURL方法,

可以在這個基礎上進行優化,使用plus.runtime.openWeb替代app打開,這個方法會新開內置窗口打開頁面,而且自帶標題欄和返回,安卓端的隱私協議文件(androidPrivacy.json)的內容中a標簽調用的即是這個方法

void plus.runtime.openWeb(url);

參數:url: ( String ) 必選 要打開的URL地址 ,僅支持http/https地址
注意標題會讀取載入html的title屬性,如果沒有的話標題顯示為空

方案3

使用app-plus的webview模塊api進行管理,
plus.webview.open( url, id, styles, aniShow, duration, showedCB )或是plus.webview.create( url, id, styles, extras );

這兩個方法都支持通過style屬性控制標題欄的樣式,如果不設置標題文字,則讀取加載的html的title屬性,具體參數支持比較多,參考文檔??????????????HTML5+ API Reference

const wv = plus.webview.open(query.src, "webview", {
titleNView: {
  autoBackButton: true,
  titleColor: "#fff",
  backgroundColor: "#0045c4",
  titleAlign: "center",
},
      })
      // wv.show()

該方案存在問題是返回操作在ios和安卓上不太一致,還可能會清除uni-app的頁面路由管理???????,不建議使用

方案4

使用uni-app的webview組件進行加載,及新建一個路由頁面,/pages/webview,內容只放一個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實現,但是dom嵌套層級太多,不方便控制寬高,所以這里就直接按條件編譯,在h5中用iframe。uni-app官方也是推薦h5中使用iframe。

app的標題欄需要通過pages.json來控制,如下參考,具體文檔見???????uni-app官網

{
    "path": "webview/index",
    "style": {
      "app-plus": {
"titleNView": {
  "backgroundColor": "#0045c4",
  "titleAlign": "center",
  "titleSize": "16px",
  "backButton": {
    "fontSize": "20px",
    "fontWeight": "bold"
  }
}
      }
    }
  }

這里titleNView的設置和方案3api的參數基本一致

總結

到此這篇關于uni-app打開外部鏈接方式(h5和app)的文章就介紹到這了,更多相關uni-app打開外部鏈接內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

標簽: JavaScript
主站蜘蛛池模板: 免费国产高清精品一区在线 | 1024cao社区榴地址一地址二 | 日本一区精品 | 亚洲欧美日韩高清一区二区三区 | 高清不卡一区二区 | 日韩欧美综合在线二区三区 | 视频在线观看一区二区 | 国产女人体一区二区三区 | 在线免费看a爱片 | 色妞干网| 成人免费播放视频777777 | 日本久久久久久久中文字幕 | 国产一级片免费 | 国产综合图区 | 欧美在线免费观看视频 | 国产福利小视频在线播放观看 | 成人性色大片 | 精品国产高清a毛片 | 黄色一级在线视频 | 成人开心激情 | 91不卡 | 国产精品久久久久乳精品爆 | 欧美精品成人一区二区视频一 | 国产a视频精品免费观看 | 国产情侣酒店自拍 | 成人丝袜激情一区二区 | 国产日韩一区二区三区在线观看 | 色屁屁www影院入口免费观看 | 国产成人在线视频免费观看 | 久久久一级| 国产二区精品视频 | 9191久久久久视频 | 毛片毛片毛片毛片出来毛片 | 亚洲欧美日韩精品久久奇米色影视 | 人成免费| 国产一区欧美二区 | 永久免费看毛片 | 欧美日本亚洲国产一区二区 | 亚洲天堂色图 | 国产一区二区三区在线 | 国产免费一区二区三区最新 |