4

为什么 Chrome 的这个功能不起作用?我正在尝试这个例子: https ://developer.chrome.com/docs/extensions/mv3/content_scripts/#programmatic 。

我正在为 chrome 开发一个扩展,并从popup.js向 service worker background.js发送一条消息,并在executeScript.

popup.js

chrome.runtime.sendMessage({ from: "newScript"}); 

清单.json

{
    "manifest_version": 3,
    "name": "TennisBet",
    "version": "1.0",
    "description": "Extrension for bet on tennis.",
    "action": {
        "default_icon": {
            "256": "images/tennis256.png",
            "128": "images/tennis128.png",
            "64": "images/tennis64.png",
            "32": "images/tennis32.png",
            "24": "images/tennis24.png",
            "16": "images/tennis16.png"
        },
        "default_popup": "popup/popup.html"
    },
    "background": {
        "service_worker": "background-wrapper.js"
    },
    "host_permissions": ["*://*/*"],
    "permissions": [
        "tabs",
        "alarms",
        "activeTab",
        "declarativeContent",
        "storage"
    ]
}

背景.js

chrome.runtime.onMessage.addListener(function(request, sender, sendResponse) {
    switch(request.from){
        case "error":
            console.log(request.message);
            break;
        case "checkTabs":
            tabsWorker();      
            break;
        case "newScript":
            chrome.scripting.executeScript({ // Error in event handler: TypeError: Cannot read property 'executeScript' of undefined
                file: "content_scripts/cscript.js"
            });
            break;
        default:
            console.log("Message listener status active");
            break;
    }
});
4

1 回答 1

20

ManifestV3 中的executeScript方法已更改,现在在chrome.scriptingAPI 中: https ://developer.chrome.com/docs/extensions/reference/scripting/

在 manifest.json 中添加这一行:

"permissions": ["scripting"] 

背景.js

chrome.scripting.executeScript({
    target: {tabId: id, allFrames: true},
    files: ['content_scripts/cscript.js'],
});
于 2021-03-09T15:59:51.510 回答