我是 JavaScript 的初学者。我需要知道这是否可行,如果可以,该怎么做。
我想创建一个 Greasemonkey 脚本,它会每小时自动重新加载一个网页,然后在重新加载页面后,我希望它为我单击一个按钮。
那可能吗?
我是 JavaScript 的初学者。我需要知道这是否可行,如果可以,该怎么做。
我想创建一个 Greasemonkey 脚本,它会每小时自动重新加载一个网页,然后在重新加载页面后,我希望它为我单击一个按钮。
那可能吗?
如需点击内容,请参阅此答案。
由于可以通过 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 个按钮的选择器可能(分别):
$("#content button.respBtn:contains('Like')");
$("#content button.respBtn:contains('Hate')");
$("#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);