JQuery:单击文档准备好的随机链接

Posted

技术标签:

【中文标题】JQuery:单击文档准备好的随机链接【英文标题】:JQuery: Click a random link on document ready 【发布时间】:2011-09-15 23:23:24 【问题描述】:

我在一个页面上有五个链接,当点击这些链接时,它们会在页面的另一部分显示不同的内容。每个链接都有一个 ID,我在文档上有一个简单的点击功能,可以选择第一个链接:

$('#link1').click();

如何让它在准备好文档时随机单击五个链接之一,而不是专门单击#link1?是的,我意识到点击函数可能不是处理这个问题的理想方法。

提前致谢!

【问题讨论】:

【参考方案1】:

另一种可能的黑客攻击:

$('a[href^="link"]').sort(function()return Math.random()-0.5).eq(0).click()

上面的代码会打乱链接,并返回第一个。 然后您可以触发返回元素的“点击”

【讨论】:

【参考方案2】:

smoov jQuery 处事方式:

jQuery.jQueryRandom = 0;
jQuery.extend(jQuery.expr[":"], 
  random: function(a, i, m, r) 
     if (i == 0) 
         jQuery.jQueryRandom = Math.floor(Math.random() * r.length);
     ;
     return i == jQuery.jQueryRandom;
  );

<script type="text/javascript">
 $().ready(function() 
     alert($("a:random").click());
 ); 
 </script>

(我知道自定义选择器,但仍然无耻地从here盗取)

稍微不那么流畅:

$(function() 
   var links = $('a');
   var randomNum = Math.floor(Math.random()*links.length)  
   links.get(randomNumber).click();
 

如果你想要一个 ID 以 link 开头的链接,你总是可以这样做:

   var links = $("a[id^='link']");

现在无论你使用数字还是其他什么都没有关系。任何具有以链接开头的 ID 的东西。 (当然,您也可以将其应用于特定的 css 类)

【讨论】:

+1 我在嘴里吐了一点,然后晕了过去。太棒了。 这太完美了!非常感谢,也感谢所有回答的人。【参考方案3】:

我认为是

links = new Array();
$('a').each(function()  links.push($(this)) );
el = links[Math.floor(Math.random()*links.length)]
el.click();

它会抓取页面上的所有链接并将它们放入一个数组中,然后单击其中一个。

【讨论】:

不需要先将它们放入数组中。 我把它拆开,这样他就可以看到这个过程,而不仅仅是复制和粘贴代码。【参考方案4】:

假设感兴趣的链接以“链接”开头,后跟一个数字:

$('a[id="link' + Math.floor(Math.random() * 5) + '"]')[0].click();

【讨论】:

【参考方案5】:

这样的?

var randomnumber=Math.floor(Math.random()*5)
$($('a').get(randomnumber)).click();

【讨论】:

更好用 .eq(): $('a').eq(randomnumber).click();

以上是关于JQuery:单击文档准备好的随机链接的主要内容,如果未能解决你的问题,请参考以下文章

jQuery介绍及文档准备就绪函数

文档准备好后,jQuery width() 立即不正确?

javascript 没有jQuery就准备好文档

javascript jQuery文档准备好了

JavaScript jQuery文档准备好了

jQuery文档内部或外部的功能准备就绪