如何使jQuery在页面加载时单击随机li元素?

时间:2019-10-11 16:13:22

标签: jquery html css

我想在我的列表的随机小组中触发.click处理程序。

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

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

也尝试过:

Click trigger on page load (UL > LI)
Auto-click button element on page load using 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>

1 个答案:

答案 0 :(得分:1)

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

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

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

(请注意,我最初说过,OP应该使用.click()而不是.trigger("click")。这是错误的,并且docs清楚地表明.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>