javascript – 从Background.js在页面级执行代码并返回值
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – 从Background.js在页面级执行代码并返回值,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3316字,纯文字阅读大概需要5分钟。
内容图文
![javascript – 从Background.js在页面级执行代码并返回值](/upload/InfoBanner/zyjiaocheng/756/0fd2ad22fc48407db9bf12c6b88349b7.jpg)
我有一个网页,里面有我自己需要执行的脚本和变量,并从我的扩展的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
>内容脚本
>实际网页(包含脚本/变量)
……我想知道从1级到3级(上图)和返回值的推荐方法是什么?
在此先感谢:o)
解决方法:
你理解3层上下文分离是完全正确的.
>后台页面是一个单独的页面,因此不会与可见页面共享JS或DOM.
>内容脚本与网页的JS上下文隔离,但共享DOM.
>您可以使用共享DOM将代码注入页面的上下文中.它可以访问JS上下文,但不能访问Chrome API.
为了进行通信,这些层使用不同的方法:
背景< - >通过Chrome API进行内容交流.
最原始的是executeScript的回调,但它对于除了单行之外的任何东西都是不切实际的.
常用的方法是使用Messaging.
不常见,但可以使用chrome.storage及其onChanged事件进行通信.
Page< - >扩展不能使用相同的技术.
由于注入的页面上下文脚本在技术上与页面自己的脚本不同,因此您正在寻找网页与扩展程序通信的方法.有两种方法可供选择:
>虽然页面对chrome.* API的访问权限非常非常有限,但他们仍然可以使用Messaging来联系扩展程序.这是通过"externally_connectable" method实现的.
我最近详细描述了this answer.简而言之,如果您的扩展声明允许域与其通信,并且域知道扩展的ID,则它可以向扩展发送外部消息.
好处是与扩展程序直接对话,但缺点是需要将您正在使用此域名的域名专门列入白名单,并且需要跟踪您的扩展ID(但是因为您注入了代码,您可以提供代码与ID).如果您需要在任何域上使用它,这是不合适的.
>另一种解决方案是使用DOM Events.由于DOM在内容脚本和页面脚本之间共享,因此一个事件生成的事件将对另一个事件可见.
该文档演示了use window.postMessage如何实现此效果;使用自定义事件在概念上更加清晰.
我再次,answered about this before.
此方法的缺点是要求内容脚本充当代理.这些行中的某些内容必须存在于内容脚本中:
window.addEventListener("PassToBackground", function(evt) {
chrome.runtime.sendMessage(evt.detail);
}, false);
后台脚本使用chrome.runtime.onMessage侦听器处理此问题.
我鼓励您编写单独的内容脚本并使用文件属性而不是代码调用executeScript,而不是依赖其回调.消息传递更清晰,允许多次将数据返回到后台脚本.
内容总结
以上是互联网集市为您收集整理的javascript – 从Background.js在页面级执行代码并返回值全部内容,希望文章能够帮你解决javascript – 从Background.js在页面级执行代码并返回值所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。