如何让jQuery在页面加载时点击一个随机的li元素?



我想在我的列表中的随机团队上触发一个 .click 处理程序。

我尝试了以下代码,但它不起作用:

$(document).ready(function(){
$('#sidebar li:nth-child() a').click();
});

还尝试过:

页面加载时的点击触发 (UL> LI(
使用 jQuery 加载页面时自动点击按钮元素

<li class="countries" id="2"><img src="{% static "images/england.png" %}" alt="england">Premier League
<ul class="subbar">
<li><a class="team" id="12">FC Liverpool</a></li>
<li><a class="team" id="13">Manchester City</a></li>
<li><a class="team" id="17">Tottenham Hotspur</a></li>
<li><a class="team" id="14">Manchester United</a></li>
<li><a class="team" id="11">Leicester City</a></li>
<li><a class="team" id="6">FC Chelsea</a></li>
<li><a class="team" id="2">FC Arsenal</a></li>
<li><a class="team" id="1">AFC Bournemouth</a></li>
<li><a class="team" id="19">West Ham United</a></li>
<li><a class="team" id="16">FC Southapmton</a></li>
<li><a class="team" id="8">FC Everton</a></li>
<li><a class="team" id="7">Crystal Palace</a></li>
<li><a class="team" id="5">Cardiff City</a></li>
<li><a class="team" id="4">FC Burnley</a></li>
<li><a class="team" id="9">Fulham</a></li>
<li><a class="team" id="3">Brighton & Hove Albion</a></li>
<li><a class="team" id="15">Newcastle United</a></li>
<li><a class="team" id="10">Huddersfield Town</a></li>
<li><a class="team" id="20">Wolverhampton Wand.</a></li>
<li><a class="team" id="18">FC Watford</a></li>
</ul>
</li>

在我开始之前,我应该说将数字作为id属性在 HTML 中是无效的。 您可以通过简单地将任何字符放在手上来修复它,例如id="a1".

应使用Math.random()根据列表中的li项数生成随机值。

您可以通过将该随机值放在nth-child部分中来创建新的选择器。

(注意,我最初说OP应该使用.trigger("click")而不是使用.click()。 这是错误的,文档清楚地表明.click()是有效的,只是.trigger("click")的快捷方式。

$(function(){
$("a.team").on("click", function(e) {
e.preventDefault();
console.log($(this)[0].id + " - " + $(this)[0].innerHTML);
});

var numLi = $(".subbar li").length;
var rnd = Math.floor(Math.random() * Math.floor(numLi)) + 1;
$(".subbar li:nth-child(" + rnd.toString() + ") a").click();
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<ul class="subbar">
<li><a class="team" id="12">FC Liverpool</a></li>
<li><a class="team" id="13">Manchester City</a></li>
<li><a class="team" id="17">Tottenham Hotspur</a></li>
<li><a class="team" id="14">Manchester United</a></li>
<li><a class="team" id="11">Leicester City</a></li>
<li><a class="team" id="6">FC Chelsea</a></li>
<li><a class="team" id="2">FC Arsenal</a></li>
<li><a class="team" id="1">AFC Bournemouth</a></li>
<li><a class="team" id="19">West Ham United</a></li>
<li><a class="team" id="16">FC Southapmton</a></li>
<li><a class="team" id="8">FC Everton</a></li>
<li><a class="team" id="7">Crystal Palace</a></li>
<li><a class="team" id="5">Cardiff City</a></li>
<li><a class="team" id="4">FC Burnley</a></li>
<li><a class="team" id="9">Fulham</a></li>
<li><a class="team" id="3">Brighton & Hove Albion</a></li>
<li><a class="team" id="15">Newcastle United</a></li>
<li><a class="team" id="10">Huddersfield Town</a></li>
<li><a class="team" id="20">Wolverhampton Wand.</a></li>
<li><a class="team" id="18">FC Watford</a></li>
</ul>

最新更新