2

我是 JavaScript 的初学者。我需要知道这是否可行,如果可以,该怎么做。

我想创建一个 Greasemonkey 脚本,它会每小时自动重新加载一个网页,然后在重新加载页面后,我希望它为我单击一个按钮。

那可能吗?

4

1 回答 1

5
  • 如需点击内容,请参阅此答案

  • 另请参阅location.reload().

  • 另请参阅更好的 javascript 参考setTimeout()

  • 由于可以通过 AJAX 加载按钮(需要问题中的更多信息),请参考实用waitForKeyElements()程序,以处理 AJAX 延迟/修改。

  • 开始学习jQuery ; 它将为您节省大量的悲伤和努力。

  • 确定所需按钮的 jQuery 选择器。您可以使用Firebug之类的工具来帮助解决此问题(请注意,jQuery 选择器和 CSS 选择器大部分相同,但 jQuery 具有更多选项/功能)。

    例如,如果页面的 HTML 有一个如下所示的部分:

    <div id="content">
        <p>Blah, blah, blather...</p>
    
        <h2>Your available actions:</h2>
        <button class="respBtn">Like</button>
        <button class="respBtn">Hate</button>
        <button id="bestOption" class="respBtn">Nuke them all</button>
    </div>
    

    然后 3 个按钮的选择器可能(分别):

    1. $("#content button.respBtn:contains('Like')");
    2. $("#content button.respBtn:contains('Hate')");
    3. $("#bestOption");(总是使用id, 如果元素有一个。)


总而言之,这是一个完整的 Greasemonkey 脚本,它可以重新加载并单击:

// ==UserScript==
// @name     _Reload and click demo
// @include  http://YOUR_SERVER.COM/YOUR_PATH/*
// @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 major design
    change introduced in GM 1.0.
    It restores the sandbox.
*/

waitForKeyElements ("#bestOption", clickTargetButton);

function clickTargetButton (jNode) {
    var clickEvent = document.createEvent ('MouseEvents');
    clickEvent.initEvent ('click', true, true);
    jNode[0].dispatchEvent (clickEvent);
}

//--- Reload after 1 hour (1000 * 60 * 60 milliseconds)
setTimeout (location.reload, 1000 * 60 * 60);
于 2012-09-19T02:57:01.367 回答