我有一個(gè)網(wǎng)頁(yè),其中包含自己的腳本和變量,我需要執(zhí)行這些腳本和變量并從擴(kuò)展程序的Background.js中檢索返回值。我了解(我認(rèn)為?。?,為了與網(wǎng)頁(yè)進(jìn)行交互,必須通過(guò)chrome.tabs.executeScript或ContentScript完成此操作,但是因?yàn)榇a必須在原始頁(yè)面的上下文中執(zhí)行(為了具有范圍) (腳本和變量),則需要先將其注入頁(yè)面。繼Rob W撰寫(xiě)的精彩文章之后,我能夠調(diào)用頁(yè)面級(jí)腳本/變量,但是我正在努力了解如何以這種方式返回值。到目前為止,這就是我所得到的...網(wǎng)頁(yè)代碼(我想與之交互):<html><head><script> var favColor = "Blue"; function getURL() { return window.location.href; }</script></head><body> <p>Example web page with script content I want interact with...</p></body></html>manifest.json:{ // Extension ID: behakphdmjpjhhbilolgcfgpnpcoamaa "name": "MyExtension", "version": "1.0", "manifest_version": 2, "description": "My Desc Here", "background": { "scripts": ["background.js"] }, "icons": { "128": "icon-128px.png" }, "permissions": [ "background", "tabs", "http://*/", "https://*/", "file://*/", //### (DEBUG ONLY) "nativeMessaging" ]}background.jscodeToExec = ['var actualCode = "alert(favColor)";', 'var script = document.createElement("script");', ' script.textContent = actualCode;', '(document.head||document.documentElement).appendChild(script);', 'script.parentNode.removeChild(script);'].join('\n');chrome.tabs.executeScript( tab.id, {code:codeToExec}, function(result) { console.log('Result = ' + result);} );我意識(shí)到代碼當(dāng)前只是在“更改” favColor變量(這只是一項(xiàng)測(cè)試,以確保我可以看到它正常工作)。但是,如果我嘗試返回該變量(通過(guò)將其保留為最后一條語(yǔ)句或說(shuō)“ return favColor”),則executeScript回調(diào)將永遠(yuǎn)沒(méi)有該值。因此,這里似乎有(至少)三個(gè)級(jí)別:background.js內(nèi)容腳本實(shí)際網(wǎng)頁(yè)(包含腳本/變量)...我想知道從1級(jí)到3級(jí)(以上)并返回值的推薦方式是什么?在此先感謝:o)
從Background.js在頁(yè)面級(jí)執(zhí)行代碼并返回值
開(kāi)心每一天1111
2019-12-06 10:01:50