3

此脚本有助于在线商店的结帐过程。一切正常,除了需要刷新页面以使程序最初运行。

我想知道这是否是缓存问题,因为它适用于以前查看过的其他产品。我也尝试修补@run-at无济于事。我正在使用Scriptish扩展,它是一个独立的.js文件。

// ==UserScript==
// @id             proper-id
// @name           proper-name
// @version        1.0
// @namespace      
// @description    
// @include        proper-url-here
// @include about:blank
// @run-at window-load
// ==/UserScript==

for (var i=0; i<document.getElementsByName("skuAndSize")[0].length; i++){
    if(document.getElementsByName("skuAndSize")[0].options[i].text == 11) {
        document.getElementsByName("skuAndSize")[0].selectedIndex = i;
    }
}
document.getElementsByClassName("button-container add-to-cart")[0].click();

为什么这个用户脚本只在刷新时运行?

4

1 回答 1

4

这是通过 AJAX 更改内容的页面的典型问题。
@run-at没有效果,因为目标内容是在窗口load事件之后很久才加载的。而且,“新”页面实际上是通过 AJAX 完全重写的——至少在您刷新页面之前。

将脚本更改为@run-at document-end(或省略该行),然后根据目标页面和您使用它的方式,可能足以触发,hashchange“我必须刷新页面以运行 Greasemonkey 脚本? " 或如this other answer所示。

但是,转到工具是waitForKeyElementsMore info。您的脚本可能很简单:

// ==UserScript==
// @name     _YOUR_SCRIPT_NAME
// @include  http://YOUR_SERVER.COM/YOUR_PATH/*
// @require  http://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js
// @require  https://gist.github.com/raw/2625891/waitForKeyElements.js
// ==/UserScript==

waitForKeyElements ("[name='skuAndSize']", setSizeIndex);
waitForKeyElements (".button-container.add-to-cart", clickAddToCart);

function setSizeIndex (jNode) {
    var node    = jNode[0];
    for (var J = node.options.length - 1;  J >= 0;  --J) {
        if (node.options[J].text == "11") {
            node.selectedIndex = J;
            break;
        }
    }
}

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


另请参阅“在 AJAX 驱动的站点上选择和激活正确的控件”

于 2013-06-29T22:17:49.203 回答