Google Chrome 扩展的内容脚本在几个页面上不起作用
Google Chrome extension's content script not working on few pages
我正在开发一个简单的 Chrome 扩展,当密码输入框获得焦点时它会执行一些操作。我正在使用以下内容脚本来实现相同的目的(代码已简化以询问此问题)。该代码不适用于 https://accounts.google.com/ but it works perfectly for pages like https://www.linkedin.com/ 这样的页面。是因为某些 Javascript/JQuery 冲突吗?还是别的什么原因?请帮忙。我尝试使用 noConflict api,但它没有帮助。
内容脚本:
var inputs = document.getElementsByTagName('input');
function foo() {
for (var i = 0; i < inputs.length; i++) {
if (inputs[i].type.toLowerCase() == 'password')
inputs[i].addEventListener("focus", bar);
}
}
function bar() {
alert(1);
}
foo();
以上脚本找到密码类型的输入元素,但没有添加事件侦听器。
清单:
{
"manifest_version": 2,
"name": "MyExtension",
"version": "1.0",
"options_page": "options.html",
"browser_action": {
"default_icon": "img/abcd.png",
"default_title": "MyExtension",
"default_popup": "popup.html"
},"icons": { "16": "img/abcd16.png",
"48": "img/abcd48.png",
"128": "img/abcd128.png" },"description":"abcd abcd",
"permissions": [
"storage","tabs"
],
"content_scripts": [
{
"matches": ["<all_urls>"
],
"js": ["js/content.js","js/jquery.1.8.3.min.js"],
"css": ["css/style.css"],
"run_at": "document_end",
"all_frames": true
}
],"web_accessible_resources": [
"img/*.png",
"css/*.css"
]
}
您是否考虑过您查找的输入字段在脚本执行时不存在? https://accounts.google.com/
是一个动态表单,密码字段是在页面加载 (document_end
) 很久之后创建的,因此在您收集 inputs
.
很久之后
除了将处理程序绑定到现有元素之外,您还需要注意添加的新元素。我建议使用 mutation-summary
library with a query {element: "input[type=password]"}
, but if you don't want to involve a library the basic building block to look at is MutationObserver
.
我正在开发一个简单的 Chrome 扩展,当密码输入框获得焦点时它会执行一些操作。我正在使用以下内容脚本来实现相同的目的(代码已简化以询问此问题)。该代码不适用于 https://accounts.google.com/ but it works perfectly for pages like https://www.linkedin.com/ 这样的页面。是因为某些 Javascript/JQuery 冲突吗?还是别的什么原因?请帮忙。我尝试使用 noConflict api,但它没有帮助。
内容脚本:
var inputs = document.getElementsByTagName('input');
function foo() {
for (var i = 0; i < inputs.length; i++) {
if (inputs[i].type.toLowerCase() == 'password')
inputs[i].addEventListener("focus", bar);
}
}
function bar() {
alert(1);
}
foo();
以上脚本找到密码类型的输入元素,但没有添加事件侦听器。
清单:
{
"manifest_version": 2,
"name": "MyExtension",
"version": "1.0",
"options_page": "options.html",
"browser_action": {
"default_icon": "img/abcd.png",
"default_title": "MyExtension",
"default_popup": "popup.html"
},"icons": { "16": "img/abcd16.png",
"48": "img/abcd48.png",
"128": "img/abcd128.png" },"description":"abcd abcd",
"permissions": [
"storage","tabs"
],
"content_scripts": [
{
"matches": ["<all_urls>"
],
"js": ["js/content.js","js/jquery.1.8.3.min.js"],
"css": ["css/style.css"],
"run_at": "document_end",
"all_frames": true
}
],"web_accessible_resources": [
"img/*.png",
"css/*.css"
]
}
您是否考虑过您查找的输入字段在脚本执行时不存在? https://accounts.google.com/
是一个动态表单,密码字段是在页面加载 (document_end
) 很久之后创建的,因此在您收集 inputs
.
除了将处理程序绑定到现有元素之外,您还需要注意添加的新元素。我建议使用 mutation-summary
library with a query {element: "input[type=password]"}
, but if you don't want to involve a library the basic building block to look at is MutationObserver
.