欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

uniapp和webview之間的通信舉例詳解

 更新時間:2025年06月11日 08:55:03   作者:DT——  
在uniapp中與webview的通信是一個常見且重要的功能,這篇文章主要介紹了uniapp和webview之間通信的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下

1.背景

應(yīng)用使用了uniapp開發(fā)跨端應(yīng)用,在uniapp中內(nèi)嵌webview頁面實現(xiàn)頁面熱更新效果,不需要用戶單獨重新安裝軟件即可實現(xiàn)頁面的版本更新。

2.webview通知uniapp

在開發(fā)過程中我們難會遇到需要uniapp和webview來實現(xiàn)數(shù)據(jù)通信的場景,接下來介紹一種可行的uniapp和webview的數(shù)據(jù)通信方案。

在webview中我們可以使用當(dāng)前webview實例的postMessage方法來觸發(fā)webview組建的onPostMessage方法來傳遞數(shù)據(jù),重點就需要放在了如何將uniapp的webview實例來加入到webview的h5項目當(dāng)中。

uniapp官方文檔中指出可以使用uni.webview.js 這個js SDK 來將當(dāng)前的uni對象注入到webview所加載的H5項目當(dāng)中。

最新版地址:https://gitcode.net/dcloud/uni-app/-/raw/dev/dist/uni.webview.1.5.6.js;

1.UniAppJSBridgeReady :

這個是在引入webview的SDK之后,當(dāng)webview頁面被加載完成之后會觸發(fā),該事件觸發(fā)表示著uniapp和webview之間的橋成功搭建,uni對象被成功的注入到當(dāng)前H5的上下文中。

我們在index.html文件中將SDK引入,這里的SDK引入必須放在body標(biāo)簽下面。

<!DOCTYPE html>
<html lang="zh-CN">
  <head>
    ...
  </head>
  <body>
    <noscript>
      <strong>Please enable JavaScript to continue.</strong>
    </noscript>
    <div id="app"></div>
    <!-- built files will be auto injected -->
  </body>
  <!-- uni 的 SDK -->
  <!-- 需要把 uni.webview.1.5.6.js 下載到自己的服務(wù)器 -->
  <script type="text/javascript" src="https://gitcode.net/dcloud/uni-app/-/raw/dev/dist/uni.webview.1.5.6.js"></script>
  <script>
    document.addEventListener('UniAppJSBridgeReady', function() {
      uni.webView.getEnv(function(res) {
        console.log('當(dāng)前環(huán)境:' + JSON.stringify(res));
      });
      // uni.webView.navigateTo(...)
    });
  </script>
</html>

2.webview中可用的uni API

方法名說明平臺差異說明
uni.navigateTonavigateTo
uni.redirectToredirectTo
uni.reLaunchreLaunch
uni.switchTabswitchTab
uni.navigateBacknavigateBack
uni.postMessage向應(yīng)用發(fā)送消息抖音小程序不支持、H5 暫不支持(可以直接使用 window.postMessage
uni.getEnv獲取當(dāng)前環(huán)境抖音小程序與飛書小程序不支持

3.發(fā)送消息

我們在H5中可以使用uni.postMessage方法來向應(yīng)用發(fā)送消息,應(yīng)用中的webview的onPostMessage方法會被觸發(fā),從而通過參數(shù)就可以拿到需要傳遞的數(shù)據(jù)。
或者因為可以使用uni.webView獲取到當(dāng)前webview實例,調(diào)用實例postMessage方法也可以傳遞數(shù)據(jù)。
注意: 這種做法在H5端是不支持的,后續(xù)會介紹H5端的處理方式。

3.uniapp 通知webview

uniapp通知webview頁面,官方提供了一種巧妙地方式。在H5項目中全局暴露一個用于接收數(shù)據(jù)的函數(shù),然后在uniapp中去觸發(fā)這個函數(shù)將參數(shù)傳遞過去即可是實現(xiàn)數(shù)據(jù)的傳遞。

evalJS

uniapp為每一個webview組件實例掛載了一個evalJS方法,用于為webview頁面注入一個可執(zhí)行的js腳本代碼。這段代碼會在webview的全局作用域中執(zhí)行。我們使用evalJS來觸發(fā)一個特定的函數(shù),在H5的全局作用域中定義對應(yīng)的函數(shù),并提前寫好對應(yīng)的數(shù)據(jù)處理邏輯。后續(xù)只需要在uniapp中觸發(fā)evalJS即可實現(xiàn)數(shù)據(jù)的傳遞。

注意:這種方式在H5端也是不支持的,后續(xù)會介紹。

4.H5中實現(xiàn)數(shù)據(jù)的通信

上述介紹的webview和uniapp的通信只針對于uniapp編譯的代碼是非H5環(huán)境,如果是H5環(huán)境則無效。因此使用postMessage 方案替代
postMessage

window.postMessage 是一個非常強(qiáng)大的 Web API,用于在不同窗口或內(nèi)嵌頁面(如 <iframe>)之間安全地傳遞消息。它允許跨源通信,即不同域名、協(xié)議或端口的頁面之間可以互相發(fā)送消息。

window.postMessage 方法允許一個窗口向另一個窗口發(fā)送消息。消息的接收方可以通過監(jiān)聽 message 事件來接收消息。為了確保安全性,postMessage 方法需要明確指定目標(biāo)窗口的來源(targetOrigin),以防止消息被發(fā)送到不安全的地址。

主頁面

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Main Page</title>
  </head>
  <body>
    <h1>Main Page</h1>
    <iframe id="myIframe" src="https://other-origin.com/iframe.html" width="600" height="400"></iframe>
    <button id="sendMessage">Send Message to Iframe</button>

    <script>
      // 獲取 iframe 的引用
      const iframe = document.getElementById('myIframe');

      // 監(jiān)聽按鈕點擊事件,向 iframe 發(fā)送消息
      document.getElementById('sendMessage').addEventListener('click', () => {
        // 確保 iframe 已加載完成
        if (iframe.contentWindow) {
          iframe.contentWindow.postMessage('Hello from main page!', 'https://other-origin.com');
        }
      });

      // 監(jiān)聽來自 iframe 的消息
      window.addEventListener('message', (event) => {
        // 驗證來源
        if (event.origin !== 'https://other-origin.com') return;

        console.log('Received message from iframe:', event.data);
      });
    </script>
  </body>
</html>

內(nèi)嵌頁面

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Iframe Page</title>
</head>
<body>
    <h1>Iframe Page</h1>
    <button id="sendMessage">Send Message to Main Page</button>

    <script>
        // 監(jiān)聽按鈕點擊事件,向主頁面發(fā)送消息
        document.getElementById('sendMessage').addEventListener('click', () => {
            // 向父窗口發(fā)送消息
            window.parent.postMessage('Hello from iframe!', '*');
        });

        // 監(jiān)聽來自主頁面的消息
        window.addEventListener('message', (event) => {
            // 驗證來源
            if (event.origin !== 'http://main-page-origin.com') return;

            console.log('Received message from main page:', event.data);
        });
    </script>
</body>
</html>

總結(jié) 

到此這篇關(guān)于uniapp和webview之間通信的文章就介紹到這了,更多相關(guān)uniapp和webview通信內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解決vue2 在mounted函數(shù)無法獲取prop中的變量問題

    解決vue2 在mounted函數(shù)無法獲取prop中的變量問題

    這篇文章主要介紹了vue2 在mounted函數(shù)無法獲取prop中的變量的解決方法 ,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-11-11
  • VUE中template的三種寫法

    VUE中template的三種寫法

    這篇文章介紹了VUE中template的三種寫法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-04-04
  • Element?plus?表單中下拉框的空值問題解決

    Element?plus?表單中下拉框的空值問題解決

    有時候會碰到查詢條件需要用下拉框來區(qū)分的時候,比如需要區(qū)分全部?|?啟用?|?停用三個狀態(tài),這時一般會給全部的value值設(shè)置為'',但是這樣會導(dǎo)致下拉框無法選中對應(yīng)的全部選項,本文就來介紹一下這個問題解決,感興趣的可以了解一下
    2024-11-11
  • Vue設(shè)置頁面全屏實例代碼

    Vue設(shè)置頁面全屏實例代碼

    文章介紹了如何在Vue中設(shè)置頁面全屏,包括下載插件、全屏、退出全屏、全屏切換等操作,同時,還分享了在若依框架中實現(xiàn)主頁面內(nèi)容全屏的方法,包括配置全局變量和在布局文件中進(jìn)行設(shè)置
    2025-02-02
  • vue如何還原data中數(shù)據(jù)-重置

    vue如何還原data中數(shù)據(jù)-重置

    這篇文章主要介紹了vue如何還原data中數(shù)據(jù)-重置問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • vue中實現(xiàn)當(dāng)前時間echarts圖表時間軸動態(tài)的數(shù)據(jù)(實例代碼)

    vue中實現(xiàn)當(dāng)前時間echarts圖表時間軸動態(tài)的數(shù)據(jù)(實例代碼)

    這篇文章主要介紹了vue中實現(xiàn)當(dāng)前時間echarts圖表時間軸動態(tài)的數(shù)據(jù),本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-10-10
  • Vue3中watch的使用詳解

    Vue3中watch的使用詳解

    這篇文章主要介紹了Vue3中watch的詳解,主要包括Vue2使用watch及Vue3使用watch的方法,通過多種情況實例代碼相結(jié)合給大家詳細(xì)講解,需要的朋友可以參考下
    2022-11-11
  • axios?發(fā)?post?請求,后端接收不到參數(shù)的完美解決方案

    axios?發(fā)?post?請求,后端接收不到參數(shù)的完美解決方案

    這篇文章主要介紹了axios?發(fā)?post?請求,后端接收不到參數(shù)的解決方案,場景很簡單,就是一個正常 axios post 請求,本文給大家分享問題原因分析及解決方案需要的朋友可以參考下
    2022-12-12
  • vue面試常考之computed是如何實現(xiàn)的

    vue面試??贾甤omputed是如何實現(xiàn)的

    對于每天都在用的計算屬性(computed),小編猜大家肯定也想窺探其奧妙與原理對吧,所以這篇文章就來講講computed是如何實現(xiàn)的吧,感興趣的小伙伴可以學(xué)習(xí)一下
    2023-08-08
  • vue 使用 v-model 雙向綁定父子組件的值遇見的問題及解決方案

    vue 使用 v-model 雙向綁定父子組件的值遇見的問題及解決方案

    這篇文章主要介紹了vue 使用 v-model 雙向綁定父子組件的值遇見的問題及解決方案,幫助大家更好的理解和學(xué)習(xí)使用vue框架,感興趣的朋友可以了解下
    2021-03-03

最新評論