0

我正在尝试制作一个运行以下代码的greasemonkey 脚本。我已经对其进行了测试,它肯定可以通过 URL (javascript: blah blah;) 减去当然的评论:

// Your country code
var cc = 'net';

var j = document.getElementsByTagName('td');
for (i=0; i <= j.length; i++) {
    if (j[[i]].innerHTML.indexOf('points - punishment #A') > 0 && j[[i]].innerHTML.length == 30) {
        var k = j[[i]].innerHTML;
        j[[i]].innerHTML = k.slice(0, 23) + '<a href="http://www.example.' + cc + '/admin.php?screen=affront_tool&mode=view_punishment&punishment_id=' + k.slice(25) + '">' + k.slice(23) + '</a>';
    }
    else if (j[[i]].innerHTML.indexOf('points - punishment #A') > 0 && j[[i]].innerHTML.length == 29) {
        var k = j[[i]].innerHTML;
        j[[i]].innerHTML = k.slice(0, 22) + '<a href="http://www.example.' + cc + '/admin.php?screen=affront_tool&mode=view_punishment&punishment_id=' + k.slice(24) + '">' + k.slice(22) + '</a>';
    }
    else if (j[[i]].innerHTML.indexOf('points - punishment') > 0 && j[[i]].innerHTML.length <= 67) {
        var k = j[[i]].getElementsByTagName('a')[0];
        var l = 'http://www.example.' + cc + '/admin.php?screen=affront_tool&mode=view_punishment&punishment_id=' + k.getAttribute('href').slice(19);
        k.setAttribute('href', l);
    }
}

不幸的是,该脚本适用于加载后最多十秒(预计大约三秒)动态生成的页面元素,这使得事情变得困难。我尝试了多种方法将脚本作为“onload”属性附加到正文,setTimeout 为一万毫秒,但无济于事。也许我应该尝试不同的方法,或者我在这个过程中重复了一个简单的错误?有人可以告诉我他们会怎么做吗?

4

1 回答 1

2

我会在您的页面上包含 jquery 库并将您的代码变成一个函数,然后执行以下操作:

$(document).ready(function () {
           setTimeout('myFunction();', 10000);
        });

在这种情况下,函数名称是“myFunction()”

于 2011-03-06T01:47:05.427 回答