首页  >  文章  >  web前端  >  如何将参数传递给使用“chrome.tabs.executeScript()”注入的内容脚本?

如何将参数传递给使用“chrome.tabs.executeScript()”注入的内容脚本?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-10-29 12:18:29206浏览

How Do I Pass Parameters to Content Scripts Injected with `chrome.tabs.executeScript()`?

将参数传递给使用 chrome.tabs.executeScript() 注入的内容脚本

使用 chrome.tabs.executeScript 注入内容脚本文件时({file: "content.js"}),一个常见的问题出现了:如何在内容脚本文件中向 JavaScript 传递参数?

参数传递谬误

需要澄清的是,您不能直接将参数传递到文件。相反,您有两种选择来实现此功能:

1。在文件执行之前设置参数

在注入文件之前嵌套 chrome.tabs.executeScript 调用来定义变量:

<code class="javascript">chrome.tabs.executeScript(tab.id, {
    code: 'var config = 1;'
}, function() {
    chrome.tabs.executeScript(tab.id, {file: 'content.js'});
});</code>

对于复杂变量,可以考虑使用 JSON.stringify 来转换对象转换为字符串:

<code class="javascript">var config = {somebigobject: 'complicated value'};
chrome.tabs.executeScript(tab.id, {
    code: 'var config = ' + JSON.stringify(config)
}, function() {
    chrome.tabs.executeScript(tab.id, {file: 'content.js'});
});</code>

在 content.js 中,您可以访问以下变量:

<code class="javascript">// content.js
alert('Example:' + config);</code>

2.文件执行后设置参数

先执行文件,然后使用消息传递API发送参数:

<code class="javascript">chrome.tabs.executeScript(tab.id, {file: 'content.js'}, function() {
    chrome.tabs.sendMessage(tab.id, 'whatever value; String, object, whatever');
});</code>

在content.js中,使用chrome监听这些消息。 runtime.onMessage 并处理消息:

<code class="javascript">chrome.runtime.onMessage.addListener(function(message, sender, sendResponse) {
    // Handle message.
    // In this example, message === 'whatever value; String, object, whatever'
});</code>

以上是如何将参数传递给使用“chrome.tabs.executeScript()”注入的内容脚本?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn