1

该网站是:lexin.nada.kth.se/lexin/#searchinfo=both,swe_gre,hej;

我的脚本是:

function main(){
  var links=document.getElementsByTagName("a");
  alert("There are " + links.length + "links.");
}

main();

运行脚本给了我两条警告消息说

有 0 个链接。

任何想法为什么我不能从文档中获得适量的链接?为什么我会收到两次警报?

4

2 回答 2

7
  1. 警报不止一次触发,因为该页面包含 iFrame(事实上,与主页具有相同的 URL)。Greasemonkey 将 iFrame 视为独立的网页。用来@noframes阻止它。

  2. 该脚本没有找到链接,因为它们是在页面加载和 GM 脚本触发后很久通过 javascript 添加的。这是脚本和 AJAX 的常见问题。一个简单、强大的解决方案是使用waitForKeyElements()(和 jQuery)。

这是一个完整的示例脚本,它避免了 iFrame,并展示了如何获取动态链接:

// ==UserScript==
// @name     _Find elements added by AJAX
// @include  http://YOUR_SERVER.COM/YOUR_PATH/*
// @match    http://stackoverflow.com/questions/*
// @require  http://ajax.googleapis.com/ajax/libs/jquery/2.1.0/jquery.min.js
// @require  https://gist.github.com/raw/2625891/waitForKeyElements.js
// @noframes
// @grant    GM_addStyle
// ==/UserScript==
/*- The @grant directive is needed to work around a design change
    introduced in GM 1.0.   It restores the sandbox.
*/
var totalUsrLinks   = 0;

waitForKeyElements ("a[href*='/users/']", listLinks);

function listLinks (jNode) {
    var usrMtch     = jNode.attr ("href").match (/^.*\/users\/(\d+)\/.*$/);
    if (usrMtch  &&  usrMtch.length > 1) {
        totalUsrLinks++;
        var usrId   = usrMtch[1];
        console.log ("Found link for user: ", usrId, "Total links = ", totalUsrLinks);
    }
}
于 2012-03-15T02:00:49.867 回答
0

它返回一个 HTMLcollection 正因为.getElementsByTagName如此,你将不得不声明 HTMLcollection,.getElementsByTagName然后找到长度,并提醒它。它看起来像这样......

 (function main(){
        var links = document.getElementsByTagName("a").length
        alert("There are "+ links + " links.");
        })()

我在这里的 IIFE 上添加了一个 IIFE 或一个立即调用函数表达式,所以你不必调用函数,所以代码很小,可以被“吞下”。最后,它会警告 2 个警报框,因为函数中有一个 [alert box] 并且您正在调用该函数,所以它会做同样的事情。

于 2019-09-17T23:37:39.383 回答