javascript - Greasemonkey 脚本不适用于动态插入的小部件

标签 javascript greasemonkey

我正在尝试编写一个 Greasemonkey 脚本,如果找到的话,它会自动将焦点集中到验证码输入字段。除了动态插入验证码形式的情况之外,这工作正常,例如 this example 。我认为为 DOMNodeInserted 创建一个事件监听器应该可以处理这种情况。 (我正在 Firefox 17b 上进行测试)。

// ==UserScript==
// @name          Focus captcha field
// @description   Adds focus on captcha fields
// ==/UserScript==

function focusCaptcha (elem) {
    var ids = ['recaptcha_response_field', 'adcopy_response', 'captcha_input'];
    for (var i = ids.length - 1; i >= 0; i--) {
        var input = elem.getElementById(ids[i]);
        if (input) {
            input.focus();
            input.value = '';
            return;
        }
    }
}

(function() {
    focusCaptcha(document);
})();

document.addEventListener('DOMNodeInserted', function(event) {
    focusCaptcha(event.target);
}, false);

最佳答案

DOMNodeInserted 是一个突变事件Mutation Events are deprecated有充分的理由。该代码可能会严重加载浏览器的 JS,并可能触发一些“脚本繁忙/失控”保护措施。

您可以切换到全新的 MutationObservers ,但这对于这类事情来说是复杂的杀伤力。

使用久经考验的waitForKeyElements() utility 。就像这样:

// ==UserScript==
// @name        _Focus captcha field
// @description Adds focus on captcha fields
// @require     http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js
// @require     https://gist.github.com/raw/2625891/waitForKeyElements.js
// @grant       GM_addStyle
// ==/UserScript==
/*- The @grant directive is needed to work around a design change introduced
    in GM 1.0.   It restores the sandbox.
*/

function focusCaptcha (jNode) {
    jNode.val ('');
    jNode[0].focus ();
}

waitForKeyElements (
    "#recaptcha_response_field, #adcopy_response, #captcha_input#",
    focusCaptcha
);
<小时/>

请注意,当尝试移动焦点时,iframe可能会使事情变得复杂(尽管尚未测试过)。

关于javascript - Greasemonkey 脚本不适用于动态插入的小部件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13278430/

相关文章:

javascript - JS 字符串与数字之间的类型转换

javascript - Document.oncontextmenu,组件不可用(firefox)

javascript - 从 Greasemonkey 脚本中删除所有 Google cookie

javascript - 使用greasemonkey重定向到域中的页面

javascript - 来自@require 脚本的@grant GM 函数

javascript - 是否可以用两个 div 创建交叉溶解?

javascript - Selenium webdriver - 无法将 'text' 转换为字符串

php - 为什么这个变量不起作用?查询

javascript - 我需要连接我的数据库然后将其显示在网页上

javascript - 使用waitForKeyElements,是否可以防止显示关键元素,只有在我的代码修改后才显示?