Chrome 扩展 运行 后台脚本,然后是内容脚本
Chrome extension run background script and then content script
点击浏览器操作后,我执行我的注入脚本,它注入了几个嵌套的 div
chrome.tabs.executeScript(tab.id, {
file: 'src/injection.js'
});
在我单击浏览器操作之前,我的内容脚本运行但无法正常工作,因为在浏览器操作中注入的 div 丢失了。有什么解决方案可以在不重新加载页面的情况下重新加载内容脚本吗?
我找到了将我的内容脚本文件放入 chrome.tabs.executeScript 函数的建议,但它不起作用
更新
manifest.json
{
"background": {
"page": "background/background.html",
"persistent": true
},
"browser_action": {
"default_icon": "img/favicon.png",
"default_title": "CheapWatcher"
},
"content_scripts": [{
"js": [
"lib/jquery.min.js",
"lib/jquery-ui.min.js",
"lib/jquery.mousewheel.js",
"lib/jquery.mCustomScrollbar.min.js",
"lib/angular.min.js",
"lib/angular-sanitize.min.js",
"lib/angular-route.min.js",
"lib/angular-ui-router.min.js"
],
"matches": [
"http://*/*",
"https://*/*"
],
"run_at": "document_end"
}],
"content_security_policy": "script-src 'self'; object-src 'self",
"description": "This extension demonstrates injection",
"manifest_version": 2,
"name": "CheapWatcher",
"permissions": [
"http://*/",
"https://*/",
"<all_urls>",
"tabs",
"cookies"
],
"version": "1.0",
"web_accessible_resources": [
"views/*.html",
"src/*.js",
"css/*.css",
"lib/*",
"img/*.png",
"img/*.gif",
"img/*.ico",
"fonts/*.ttf",
"fonts/*.otf"
]
}
我从 background.js
打电话给 chrome.tabs.executeScript
chrome.browserAction.onClicked.addListener(function (tab) {
if (pageRefreshed === true || pageRefreshed === false && sidebarActive === false && buttonClickedCount === 0 && newTab === false || newTab === true) {
chrome.tabs.executeScript(null, {file: "src/injection.js"});
chrome.tabs.executeScript(null, {file: "src/app.js"});
chrome.tabs.executeScript(null, {file: "src/MainController.js"});
chrome.tabs.executeScript(null, {file: "src/LoginController.js"});
chrome.tabs.executeScript(null, {file: "src/ListController.js"});
chrome.tabs.executeScript(null, {file: "src/ErrorController.js"});
chrome.tabs.executeScript(null, {file: "src/NotifyController.js"});
chrome.tabs.executeScript(null, {file: "src/TargetController.js"});
chrome.tabs.executeScript(null, {file: "src/RegisterController.js"});
chrome.tabs.executeScript(null, {file: "src/ResetPassController.js"});
chrome.tabs.executeScript(null, {file: "src/ScrollTargetController.js"});
chrome.tabs.executeScript(null, {file: "src/SetTargetController.js"});
chrome.tabs.executeScript(tab.id, {
code: "$('.cheap-watcher' ).animate({ 'right': '0px' }, 'slow');"
});
sidebarActive = true;
buttonClickedCount = 1;
newTab = false;
pageRefreshed = false;
}
else if (sidebarActive === true && buttonClickedCount > 0) {
chrome.tabs.executeScript(tab.id, {
code: "$('.cheap-watcher' ).animate({ 'right': '-370px' }, 'slow');"
});
sidebarActive = false;
}
else if (sidebarActive === false && buttonClickedCount > 0) {
chrome.tabs.executeScript(tab.id, {
code: "$('.cheap-watcher' ).animate({ 'right': '0px' }, 'slow');"
});
sidebarActive = true;
}
});
是的,我知道这种编码是一种不好的做法,但我只是想让我的扩展工作,但到目前为止运气不好。消息传递也无济于事。
所以我所做的一切都很好,但我唯一错过的是手动 bootstrap 我的 angular 模块,所以我只是在我的 SetTargetController.js 中写了这段代码(因为这是注入的最后一个 angular 文件)
angular.element(document).ready(function() {
angular.bootstrap(document, ['app']);
});
点击浏览器操作后,我执行我的注入脚本,它注入了几个嵌套的 div
chrome.tabs.executeScript(tab.id, {
file: 'src/injection.js'
});
在我单击浏览器操作之前,我的内容脚本运行但无法正常工作,因为在浏览器操作中注入的 div 丢失了。有什么解决方案可以在不重新加载页面的情况下重新加载内容脚本吗?
我找到了将我的内容脚本文件放入 chrome.tabs.executeScript 函数的建议,但它不起作用
更新
manifest.json
{
"background": {
"page": "background/background.html",
"persistent": true
},
"browser_action": {
"default_icon": "img/favicon.png",
"default_title": "CheapWatcher"
},
"content_scripts": [{
"js": [
"lib/jquery.min.js",
"lib/jquery-ui.min.js",
"lib/jquery.mousewheel.js",
"lib/jquery.mCustomScrollbar.min.js",
"lib/angular.min.js",
"lib/angular-sanitize.min.js",
"lib/angular-route.min.js",
"lib/angular-ui-router.min.js"
],
"matches": [
"http://*/*",
"https://*/*"
],
"run_at": "document_end"
}],
"content_security_policy": "script-src 'self'; object-src 'self",
"description": "This extension demonstrates injection",
"manifest_version": 2,
"name": "CheapWatcher",
"permissions": [
"http://*/",
"https://*/",
"<all_urls>",
"tabs",
"cookies"
],
"version": "1.0",
"web_accessible_resources": [
"views/*.html",
"src/*.js",
"css/*.css",
"lib/*",
"img/*.png",
"img/*.gif",
"img/*.ico",
"fonts/*.ttf",
"fonts/*.otf"
]
}
我从 background.js
打电话给chrome.tabs.executeScript
chrome.browserAction.onClicked.addListener(function (tab) {
if (pageRefreshed === true || pageRefreshed === false && sidebarActive === false && buttonClickedCount === 0 && newTab === false || newTab === true) {
chrome.tabs.executeScript(null, {file: "src/injection.js"});
chrome.tabs.executeScript(null, {file: "src/app.js"});
chrome.tabs.executeScript(null, {file: "src/MainController.js"});
chrome.tabs.executeScript(null, {file: "src/LoginController.js"});
chrome.tabs.executeScript(null, {file: "src/ListController.js"});
chrome.tabs.executeScript(null, {file: "src/ErrorController.js"});
chrome.tabs.executeScript(null, {file: "src/NotifyController.js"});
chrome.tabs.executeScript(null, {file: "src/TargetController.js"});
chrome.tabs.executeScript(null, {file: "src/RegisterController.js"});
chrome.tabs.executeScript(null, {file: "src/ResetPassController.js"});
chrome.tabs.executeScript(null, {file: "src/ScrollTargetController.js"});
chrome.tabs.executeScript(null, {file: "src/SetTargetController.js"});
chrome.tabs.executeScript(tab.id, {
code: "$('.cheap-watcher' ).animate({ 'right': '0px' }, 'slow');"
});
sidebarActive = true;
buttonClickedCount = 1;
newTab = false;
pageRefreshed = false;
}
else if (sidebarActive === true && buttonClickedCount > 0) {
chrome.tabs.executeScript(tab.id, {
code: "$('.cheap-watcher' ).animate({ 'right': '-370px' }, 'slow');"
});
sidebarActive = false;
}
else if (sidebarActive === false && buttonClickedCount > 0) {
chrome.tabs.executeScript(tab.id, {
code: "$('.cheap-watcher' ).animate({ 'right': '0px' }, 'slow');"
});
sidebarActive = true;
}
});
是的,我知道这种编码是一种不好的做法,但我只是想让我的扩展工作,但到目前为止运气不好。消息传递也无济于事。
所以我所做的一切都很好,但我唯一错过的是手动 bootstrap 我的 angular 模块,所以我只是在我的 SetTargetController.js 中写了这段代码(因为这是注入的最后一个 angular 文件)
angular.element(document).ready(function() {
angular.bootstrap(document, ['app']);
});