- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有一个网页,它有自己的脚本和变量,我需要执行这些脚本和变量并从我的扩展程序的 Background.js 中检索返回值。
我理解(我认为!)为了与网页交互,必须通过 chrome.tabs.executeScript 或 ContentScript 完成,但因为代码必须在原始页面的上下文中执行(为了具有脚本和变量的作用域),需要先将其注入(inject)页面。
关注此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>
list .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 回调永远不会有值。
所以,这里似乎(至少)有三个层次:
...我想知道从第 1 级到第 3 级(以上)和返回值的推荐方式是什么?
提前致谢:o)
最佳答案
您对 3 层上下文分离的理解非常正确。
为了进行通信,这些层使用不同的方法:
背景 <-> 内容 通过 Chrome API 讨论。
最原始的是 executeScript
的回调,但除了单行代码外,它不切实际。
常见的方法是使用 Messaging .
不常见,但可以使用 chrome.storage
及其 onChanged
事件进行通信。
页面<->扩展不能使用相同的技术。
由于注入(inject)的页面上下文脚本在技术上与页面自己的脚本没有区别,因此您正在寻找网页与扩展程序对话的方法。有两种方法可用:
虽然页面对 chrome.*
API 的访问非常非常有限,但它们仍然可以使用 Messaging 来联系扩展程序。这是通过 "externally_connectable"
method 实现的.
我最近详细描述了它this answer .简而言之,如果您的扩展程序声明允许某个域与其通信,并且该域知道该扩展程序的 ID,则它可以向该扩展程序发送外部消息。
好处是直接与扩展程序对话,但缺点是需要将您正在使用它的特定域列入白名单,并且您需要跟踪您的扩展程序 ID(但由于您正在注入(inject)代码,您可以提供带有 ID 的代码)。如果您需要在任何域上使用它,这是不合适的。
另一种解决方案是使用 DOM 事件。由于 DOM 在内容脚本和页面脚本之间共享,因此一个事件生成的事件将对另一个可见。
文档演示了如何 use window.postMessage
为了这个效果;使用自定义事件在概念上更加清晰。
同样,我 answered about this before .
此方法的缺点是要求内容脚本充当代理。内容脚本中必须包含以下内容:
window.addEventListener("PassToBackground", function(evt) {
chrome.runtime.sendMessage(evt.detail);
}, false);
当后台脚本使用 chrome.runtime.onMessage
监听器处理它时。
我鼓励您编写一个单独的内容脚本并使用 file
属性而不是 code
调用 executeScript
,并且不依赖于它的回调.消息传递更清晰,并允许多次将数据返回到后台脚本。
关于javascript - 从 Background.js 在页面级执行代码并返回值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26140443/
我是 os 2 的新手,所以真的不知道从哪里开始。是否可以编写一个 WatchOs 2 应用程序,它将在后台运行并每小时唤醒一次?网上没有那么多可用的信息,但到目前为止我所看到的表明不可能编写后台应用
如何将 url 背景图像添加到渐变中并具体定位?因为梯度本身被当作图像 CSS background: linear-gradient(to bottom, #98cb01 2%,#60a822 10
我是 android 开发的新手,正在开发我的第一个 android 应用程序。我在布局的 xml 中设置了 View 的背景颜色,如下所示。 android:background="@+color/
为了尽可能简洁地使用样式,如果使用双像素密度设备(例如 iPhone 4)查看我的页面,我宁愿不使用包含的媒体查询样式表。 话虽如此,如果我只是做这样的事情就可以了吗? .icon-1 { bac
我有一个由 62 张 91 * 91 像素的图像组成的 Sprite ,这使得整个图像为 91 * 5642 像素。它们以动态网格的形式显示,该网格会根据用户/指针的移动而增长和缩小。有时,一个元素(
我一直在尝试制作一款使用 Xbox One Kinect (V2) 的 Unity 游戏。 我遵循了本教程中的说明: http://www.imaginativeuniversal.com/blog/
看来firefox会自动组合一些东西,例如它需要单独的css值,例如“border-color”,“border-width”并将它们全部转储到“border”中..这使jquery变得很痛苦因为 .
我正在构建我的第一个 Chrome 扩展程序。我浏览了 Chrome 开发人员文档,但我无法理解几个主题。 我的理解: 有两个 Action : 浏览器操作(地址栏外的按钮) 页面操作(地址栏内的按钮
我的后台监听器是 chrome.runtime.onMessage.addListener(function (request, sender, sendResponse) 在chrome.conte
哪个更有效: 我正在尝试找出哪种提供半透明背景的方法更有效/更快: background-color: rgba(255, 255, 255, .12); 或者 background-image: u
我想要一个有 tr 作为黑色背景的表格,里面有一个白色背景的表格。
我在我的主页上放了一个背景。它可以在除 android chrome 之外的所有浏览器上正确显示。这是我的 CSS: body.path-frontpage { background-imag
我正在尝试对我的背景图像应用滤镜,但是我遇到了 CSS 属性 URL 和线性渐变的问题。我想要的背景图片 .bg-image-full { background: no-repeat center
在样式部分的 chrome 中使用谷歌开发者控制台时,它会立即为我提供“在我键入时”的背景颜色属性。几个月前,它一直在提供我更喜欢的一般属性(property)“背景”。 是否有机会自定义这些提示,或
我正在尝试实现 faux column网站上的布局。简而言之,它涉及在包含两个垂直列的 div 上平铺背景图像,使其看起来像两个列一直延伸到底部。 我的专栏如下所示: XXXX MMMM XXXX
这是一个 example .我想裁剪背景图像,然后将裁剪图像用作更大(尺寸)元素的背景。我的意思是 div 比它的背景大,我不需要重复。现在,当 background-repeat 取消注释时,元素消
CSS3 声明 background-clip 和 background-origin 似乎对背景有相同的效果。它们似乎都将背景限制在相对于 HTML 元素的某个区域,所以我想知道这两个声明在功能上是
我正在为图片库制作缩略图页面。缩略图预览作为 完成 float 具有固定的方形尺寸。 然而,缩略图本身不一定是正方形或相同大小,它们具有它们所代表的大图像的属性。 为了让它看起来不错,我想在正方形中
这个问题在这里已经有了答案: Get a CSS value with JavaScript (8 个答案) 关闭 6 年前。
你好, 就像我在标题中所说的 background-image:none; 不起作用,因为使用 css3 background-image:url('...'); 返回一个新层每次文件都是新的。我正在
我是一名优秀的程序员,十分优秀!