我有一个自己的脚本和变量的网页,我需要执行并从我的扩展的Background.js中检索返回值。从Background.js在页面级执行代码并返回值
我明白(我想!)为了与网页交互,它必须通过chrome.tabs.executeScript或ContentScript来完成,但因为代码必须在原始页面的上下文中执行(在为了使脚本和变量具有作用域),它需要首先注入页面。
在此great post by Rob W之后,我可以调用页面级脚本/变量,但我很努力去理解如何以这种方式返回值。
这里就是我这么远......
网页代码(我想与互动):
<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.js
codeToExec = ['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);
});
我意识到代码目前只是“提醒”favColor变量(这只是一个测试,以确保我能看到它的工作)。但是,如果我尝试返回该变量(通过将其保留为最后一个语句或通过说“return favColor”),executeScript回调从不具有该值。
因此,似乎有(至少)三个级别的位置:
- background.js
- 内容脚本
- 实际网页(含脚本/变量)
...我想知道什么是rec从1级到3级(上图)进行交谈并返回值?
在此先感谢:o)
你理解上下文的划分方式非常正确,赞誉和+1。即将回答。 – Xan 2014-10-01 11:40:20
(...感谢您的信心助推器!) – 2014-10-01 14:45:12