国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

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

這篇具有很好參考價(jià)值的文章主要介紹了如何Uniapp中嵌入H5,并且在H5中跳轉(zhuǎn)到APP的指定頁(yè)面。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問(wèn)。

場(chǎng)景

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

Web-View

在uniapp中,有一個(gè)web-view組件,這就相當(dāng)于一個(gè)瀏覽器組件,可以用來(lái)承載網(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的地址什么的沒(méi)有關(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)如下
如何Uniapp中嵌入H5,并且在H5中跳轉(zhuǎn)到APP的指定頁(yè)面

對(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的問(wèn)題,但是使用uniapp開(kāi)發(fā)H5就會(huì)失效,在uniapp開(kāi)發(fā)H5頁(yè)面使用 uni.reLaunch 只能跳轉(zhuǎn)到H5項(xiàng)目本地的頁(yè)面。

解決方法如下

1. 下載官網(wǎng)web-view的SDK

如何Uniapp中嵌入H5,并且在H5中跳轉(zhuǎn)到APP的指定頁(yè)面
在官網(wǎng)的原生H5 demo 導(dǎo)入了這個(gè)關(guān)鍵的Js文件,通過(guò)瀏覽器打開(kāi)
https://unpkg.com/@dcloudio/uni-webview-js@0.0.3/index.js
如何Uniapp中嵌入H5,并且在H5中跳轉(zhuǎn)到APP的指定頁(yè)面
復(fù)制里面的JS代碼
在H5項(xiàng)目里創(chuàng)建一個(gè)js文件 web-view.js,內(nèi)容即是以上js代碼

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

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

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

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

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

區(qū)別在于 uniapp開(kāi)發(fā)的H5要加上 webView文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-445372.html

到了這里,關(guān)于如何Uniapp中嵌入H5,并且在H5中跳轉(zhuǎn)到APP的指定頁(yè)面的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來(lái)自互聯(lián)網(wǎng)用戶(hù)投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • 微信小程序web-view嵌入uni-app H5頁(yè)面,通過(guò)H5頁(yè)面跳轉(zhuǎn)企業(yè)微信客戶(hù)聊天窗口如何操作?

    微信小程序web-view嵌入uni-app H5頁(yè)面,通過(guò)H5頁(yè)面跳轉(zhuǎn)企業(yè)微信客戶(hù)聊天窗口如何操作?

    1)找到企業(yè)ID,登錄?企業(yè)微信 企業(yè)微信 https://work.weixin.qq.com/wework_admin/loginpage_wx ?2)找到接入鏈接? 功能-客服-微信客服 微信公眾平臺(tái),給個(gè)人、企業(yè)和組織提供業(yè)務(wù)服務(wù)與用戶(hù)管理能力的全新服務(wù)平臺(tái)。 https://mp.weixin.qq.com/

    2024年02月11日
    瀏覽(97)
  • uniapp項(xiàng)目編譯成H5后跳轉(zhuǎn)到微信小程序(支持微信掃碼、支付寶掃碼)

    uniapp項(xiàng)目編譯成H5后跳轉(zhuǎn)到微信小程序(支持微信掃碼、支付寶掃碼)

    uniapp項(xiàng)目編譯成 H5 后跳轉(zhuǎn)到 微信小程序 (支持微信H5、支付寶H5) 場(chǎng)景:1、微信掃碼跳轉(zhuǎn)到該H5中后點(diǎn)擊某事件(或者不點(diǎn)擊直接跳轉(zhuǎn))需要跳轉(zhuǎn)到微信小程序;2、支付寶掃碼跳轉(zhuǎn)到H5中后點(diǎn)擊某事件(或者不點(diǎn)擊直接跳轉(zhuǎn))需要跳轉(zhuǎn)到微信小程序 思路:調(diào)用后端接口返回

    2024年02月13日
    瀏覽(96)
  • uniapp實(shí)現(xiàn)支付寶小程序中嵌入H5并且實(shí)現(xiàn)相互通信

    uniapp實(shí)現(xiàn)支付寶小程序中嵌入H5并且實(shí)現(xiàn)相互通信

    場(chǎng)景:在小程序開(kāi)發(fā)中(無(wú)論是支付寶、微信、Uniapp等)會(huì)遇到在小程序中使用或者跳轉(zhuǎn)一些自己的公司開(kāi)發(fā)過(guò)的,或三方地址,在小程序中的開(kāi)發(fā)文檔中大家可以看到,只是有一些基本的內(nèi)部跳轉(zhuǎn)方式,但通過(guò)僅有的跳轉(zhuǎn)方式無(wú)法滿足我們的跳轉(zhuǎn)外部頁(yè)面的需求,這個(gè)時(shí)候

    2024年01月19日
    瀏覽(22)
  • iOS-自定義Intent及ShortCut,能通過(guò)快捷指令喚醒APP并跳轉(zhuǎn)到指定頁(yè)面

    iOS-自定義Intent及ShortCut,能通過(guò)快捷指令喚醒APP并跳轉(zhuǎn)到指定頁(yè)面

    創(chuàng)建完成后,在intents文件中勾選以下target,否則在擴(kuò)展里,無(wú)法訪問(wèn)到前面創(chuàng)建的Intent類(lèi) 編譯程序,Xcode 會(huì)自動(dòng)生成對(duì)應(yīng)的類(lèi),我這里的話會(huì)生成 LaunchAppIntent 類(lèi),下面需要使用 引入上述生成的文件,并寫(xiě)入代理,如果之前未勾選target是無(wú)法引入的 在代理中寫(xiě)入,以及點(diǎn)擊

    2024年01月23日
    瀏覽(47)
  • 如何從短信鏈接打開(kāi)跳轉(zhuǎn)到微信App內(nèi)

    如何從短信鏈接打開(kāi)跳轉(zhuǎn)到微信App內(nèi)

    運(yùn)營(yíng)做了一個(gè)活動(dòng),準(zhǔn)備發(fā)送短信推廣出去,結(jié)果問(wèn)題來(lái)了,用戶(hù)接收到短信后,點(diǎn)擊短信里的鏈接,默認(rèn)是用的系統(tǒng)瀏覽器打開(kāi)的,但我們的活動(dòng)是用微信支付啊~~~微信支付啊~~~ 系統(tǒng)瀏覽器里不支持?。。?! 如何才能讓用戶(hù)點(diǎn)擊鏈接后打開(kāi)微信呢? 上網(wǎng)搜了一圈,發(fā)現(xiàn)小

    2024年02月08日
    瀏覽(18)
  • uniapp 小程序如何從主包頁(yè)面跳轉(zhuǎn)到分包頁(yè)面

    uniapp 小程序如何從主包頁(yè)面跳轉(zhuǎn)到分包頁(yè)面

    在uniapp開(kāi)發(fā)小程序的時(shí)候,“分包”概念一定要提前了解下,具體我就不多說(shuō)了,自己看下關(guān)網(wǎng)的相關(guān)配置。 那么,如果從主包頁(yè)面,跳轉(zhuǎn)至分包的頁(yè)面呢?如圖所示 我的頁(yè)面-詳情頁(yè)? 在我的頁(yè)面創(chuàng)建好自己的鏈接,我使用的是方法創(chuàng)建的 注: 1、一定要注意跳轉(zhuǎn)的路徑,

    2024年02月16日
    瀏覽(28)
  • uniapp微信小程序中跳轉(zhuǎn)頁(yè)面的方法

    在 UniApp 中,有多種方法可以實(shí)現(xiàn)頁(yè)面跳轉(zhuǎn),以下是其中幾種常用的方法及其區(qū)別: uni.navigateTo : 使用該方法進(jìn)行頁(yè)面跳轉(zhuǎn)時(shí),會(huì)關(guān)閉當(dāng)前頁(yè)面,跳轉(zhuǎn)到指定的頁(yè)面。 可以在目標(biāo)頁(yè)面中獲取傳遞的數(shù)據(jù),通過(guò)? data-url ?或? data-object ?傳遞。 通常用于跳轉(zhuǎn)到新頁(yè)面并關(guān)閉當(dāng)前

    2024年02月03日
    瀏覽(23)
  • js跳轉(zhuǎn)到指定url

    js跳轉(zhuǎn)到指定url

    js怎么跳轉(zhuǎn)到指定url方法如下: 需求:頁(yè)面上點(diǎn)擊按鈕 需要調(diào)用設(shè)備提供的地址

    2024年02月11日
    瀏覽(20)
  • HTML跳轉(zhuǎn)到頁(yè)面指定位置

    使用純超鏈接實(shí)現(xiàn) 1. 實(shí)現(xiàn)本頁(yè)面跳轉(zhuǎn)到指定位置(a.html),代碼如下: 2. 實(shí)現(xiàn)點(diǎn)擊跳轉(zhuǎn)到新頁(yè)面的指定位置,代碼如下: 如果上方有導(dǎo)航條遮擋 ?

    2024年02月12日
    瀏覽(99)

覺(jué)得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包