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

electron的webview和內嵌網頁通信的方法

 更新時間:2024年04月15日 10:56:18   作者:yezi__626  
在 Electron 的世界里,webview 標簽相當于一個小盒子,里面可以裝一個完整的網頁,就像一個迷你瀏覽器,這篇文章主要介紹了electron的webview和內嵌網頁如何通信,需要的朋友可以參考下

在 Electron 的世界里,webview 標簽相當于一個小盒子,里面可以裝一個完整的網頁,就像一個迷你瀏覽器。當你想和這個小盒子里的內容說話時(也就是進行通信),這里有幾個方法可以幫你做到:
這里只寫了兩種方式,如果要是來找方案的客官。那直接看2就好。

1. 使用 preload 腳本

通過在 webview 標簽中使用 preload 屬性來指定一個腳本,該腳本在網頁加載之前執(zhí)行,但在網頁的 JavaScript 環(huán)境中運行。這允許在不暴露全部 Node.js API 的情況下,向網頁注入特定的 API 或者設置監(jiān)聽函數來實現雙向通信。

<webview id="foo" src="http://example.com" preload="path/to/preload.js"></webview>

在 preload 腳本中,你可以使用 ipcRenderer 和 contextBridge 來安全地暴露功能:

const { contextBridge, ipcRenderer } = require('electron');
contextBridge.exposeInMainWorld('electronAPI', {
    sendMessage: (message) => ipcRenderer.send('message-from-webview', message)
});
window.addEventListener('DOMContentLoaded', () => {
  // 從主進程接收消息
  ipcRenderer.on('message-to-webview', (event, data) => {
    console.log(data);
  });
});

【該方法目前遇到問題如下:】
webview內部頁面加載報錯:

2.postMessage

由于webview 標簽創(chuàng)建了一個獨立的渲染進程,它和主應用的渲染進程是隔離的。因此,webview 內部的頁面擁有自己的全局 window 對象,你不能直接從外部的渲染進程訪問 webview 內的 window 對象。

當你調用 webviewEl.executeJavaScript 方法時,你實際上是在 webview 內的上下文中執(zhí)行 JavaScript 代碼,因此可以通過注入腳本進行交互。

(1)electron的App.tsx模塊發(fā)消息給webview內的頁面:

const handleSendMessage = () => {
    if (webview.current) {
      const message = { type: 'messageFromElectron', text: '這里是electron發(fā)送的消息:electron->view' };
      const script = `window.postMessage(${JSON.stringify(message)}, '*')`;
      webview.current.executeJavaScript(script);
    }
  };

在webview內的頁面接收:

mounted(){
  const handleWebviewMessage = (event) => {
    const message = event.data;
    if (typeof message === 'object' && message !== null) {
      switch (message.type) {
        case 'messageFromElectron':
          console.info('Electron的消息', message);
          break;
        default:
          console.warn('接收到未知類型的消息', message);
      }
    }
  };
  window.addEventListener('message',handleWebviewMessage); 
},

(2)webview內的頁面發(fā)送消息給electron

 sendMessageToElectron(){
      window.postMessage({ type: 'messageFromView', text: 'Hello from Vue!' }, '*');
    },

electron的App.tsx接收:

const handleWebviewMessage = (event) => {
    const message = event.data;
    if (typeof message === 'object' && message !== null) {
      switch (message.type) {
        case 'messageFromView':
          console.info('這里是webview的消息:webview->electron', message);
          break;
        default:
          console.warn('接收到未知類型的消息', message);
      }
    }
  };
    useEffect(() => {
    	const webviewEl = webview.current;
   		const handleDomReady = () => {
      		// 為 webview 內的 window 對象添加 message 事件監(jiān)聽器
      		webviewEl.executeJavaScript(`
     		 window.addEventListener('message', ${handleWebviewMessage.toString()})
    `);
    	};
    	if (webviewEl) {
      		webviewEl.addEventListener('dom-ready', handleDomReady);
   		 }
     // 清理工作
    	return () => {
      	if (webviewEl) {
        	// 移除之前添加的事件監(jiān)聽器,避免內存泄漏
        	webviewEl.removeEventListener('dom-ready', handleDomReady);
      	}
    	};
  	}, []);

知識科普:
executeJavaScript

executeJavaScript 方法的主要作用是在瀏覽器環(huán)境中異步執(zhí)行 JavaScript 代碼。這個方法是 Electron 中
webContents 對象提供的一個功能,允許開發(fā)者在 web 頁面的上下文中運行任意的 JavaScript 代碼字符串。

由于我使用的是react框架的ref來引用webview組件的,因此需要通過這個引用來獲取 webview 的 webContents,進而使用 executeJavaScript 方法。
使用場景:
● 與頁面交互:你可以使用 executeJavaScript 來注入和執(zhí)行自定義腳本,從而與網頁中的 DOM 進行交互,修改網頁內容,或者觸發(fā)在網頁中定義的 JavaScript 函數。

webview.executeJavaScript('document.getElementById("myButton").click()');

● 獲取頁面信息:通過執(zhí)行返回值的 JavaScript 代碼,你可以獲取網頁中的數據,比如頁面標題、選定的文本或其他 DOM 元素的屬性。

webview.executeJavaScript('document.title')
  .then(title => {
    console.log(`The page title is ${title}`);
  });

● 網頁自動化:可以用它來自動化測試網頁的行為,例如自動填充表單、點擊按鈕等。

webview.executeJavaScript(`
  document.getElementById('username').value = 'exampleUser';
  document.getElementById('password').value = 'examplePass';
  document.getElementById('login-form').submit();
`);

到此這篇關于electron的webview和內嵌網頁通信的方法的文章就介紹到這了,更多相關electron webview通信內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • js 多層疊的TAB選項卡

    js 多層疊的TAB選項卡

    一個多層疊的TAB選項卡,自適應寬度(自行更改nonstop的width測試效果)。
    2010-01-01
  • Bootstrap CSS布局之按鈕

    Bootstrap CSS布局之按鈕

    這篇文章主要介為大家詳細紹了Bootstrap CSS布局之按鈕的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • JavaScript使用ul中l(wèi)i標簽實現刪除效果

    JavaScript使用ul中l(wèi)i標簽實現刪除效果

    這篇文章主要為大家詳細介紹了JavaScript使用ul中l(wèi)i標簽實現刪除效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-04-04
  • JavaScript中引用vs復制示例詳析

    JavaScript中引用vs復制示例詳析

    這篇文章主要給大家介紹了關于JavaScript中引用vs復制的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-12-12
  • 對layer彈出框中icon數字參數的說明介紹

    對layer彈出框中icon數字參數的說明介紹

    今天小編就為大家分享一篇對layer彈出框中icon數字參數的說明介紹,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • 原生JS 實現的input輸入時表格過濾操作示例

    原生JS 實現的input輸入時表格過濾操作示例

    這篇文章主要介紹了原生JS 實現的input輸入時表格過濾操作,結合實例形式分析了JavaScript基于頁面元素遍歷、運算、判斷實現的表格過濾相關操作技巧,需要的朋友可以參考下
    2019-08-08
  • JS實現左側菜單工具欄

    JS實現左側菜單工具欄

    這篇文章主要為大家詳細介紹了JS實現左側菜單工具欄,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • JavaScript獲取瀏覽器窗口尺寸的幾種方法

    JavaScript獲取瀏覽器窗口尺寸的幾種方法

    JavaScript是一種廣泛使用的腳本語言,用于開發(fā)網頁和應用程序,在Web開發(fā)中,經常需要獲取瀏覽器窗口的尺寸,以便根據窗口大小進行布局或執(zhí)行其他操作,本文將介紹如何使用JavaScript來獲取瀏覽器窗口尺寸,需要的朋友可以參考下
    2023-11-11
  • JS實現鼠標經過好友列表中的好友頭像時顯示資料卡的效果

    JS實現鼠標經過好友列表中的好友頭像時顯示資料卡的效果

    需求為當用戶鼠標經過好友列表中好友頭像時,顯示該好友的基本資料,其實也就是類似QQ客戶端的那種功能,下面是具體的實現思路及過程
    2014-07-07
  • JS中的XMLHttpRequest?對象示例詳解

    JS中的XMLHttpRequest?對象示例詳解

    xmlhttp是一種瀏覽器對象,?可用于模擬http的GET和POST請求,xmlhttp配合JavaScript可以實現頁面數據在無刷新下的定時數據更新,如果應用在聊天室、文字直播上,可以取得較好的視覺效果,這篇文章主要介紹了JS——XMLHttpRequest?對象,需要的朋友可以參考下
    2024-01-01

最新評論