如何为每个选项卡设置计时器而不是数组

How to set timer per tab not array

我有一个在选项卡之间切换的代码。 计时器设置为在所有选项卡之间切换。 我想为每个选项卡设置计时器 示例:

tab 1 = 5 seconds tab 2 = 10 seconds tab 3 = 1 minute

<script type="text/javascript" src="js/jquery-1.4.4.min.js"></script>
<script type="text/javascript" src="js/jquery.easyui.min.js"></script>


<script>
    $(function(){
        var index = 0;
        var t = $('#tt');
        var tabs = t.tabs('tabs');
        setInterval(function(){
            t.tabs('select', tabs[index].panel('options').title);
            index++;
            if (index >= tabs.length){
                index = 0;
            }
        }, 10000);

    });


</script>



<div id="tt" class="easyui-tabs">
<div title="1"></div>
<div title="2"></div>
<div title="3"></div>
</div>

您应该能够将其应用到您的代码中。这是一个 jQuery 标签示例。你基本上需要时间元素。

不清楚您是否需要重复或停止。这个例子重复,我包括了一个停止它的方法。

$(function() {
  var s = [5, 10, 60];
  var c = 0;
  var tt = $("#tt").tabs({
    active: 0
  });
  var intr = setInterval(function() {
    // i = Current Active Tab Index
    var i = tt.tabs("option", "active");
    if (c == s[i]) {
      console.log("Switch", c);
      //Activate Next Tab
      tt.tabs("option", "active", ++i);
    }
    c++;
    if (c > s[s.length - 1]) {
      // Repeat
      tt.tabs("option", "active", 0);
      c = 0;
      // Stop
      // clearInterval(intr);
    }
  }, 1000);
});
<link rel="stylesheet" href="//code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css">
<script src="https://code.jquery.com/jquery-1.12.4.js"></script>
<script src="https://code.jquery.com/ui/1.12.1/jquery-ui.js"></script>
<div id="tt">
  <ul>
    <li><a href="#tabs-1">Nunc tincidunt</a></li>
    <li><a href="#tabs-2">Proin dolor</a></li>
    <li><a href="#tabs-3">Aenean lacinia</a></li>
  </ul>
  <div id="tabs-1">
    <p>Proin elit arcu, rutrum commodo, vehicula tempus, commodo a, risus. Curabitur nec arcu. Donec sollicitudin mi sit amet mauris. Nam elementum quam ullamcorper ante. Etiam aliquet massa et lorem. Mauris dapibus lacus auctor risus. Aenean tempor ullamcorper
      leo. Vivamus sed magna quis ligula eleifend adipiscing. Duis orci. Aliquam sodales tortor vitae ipsum. Aliquam nulla. Duis aliquam molestie erat. Ut et mauris vel pede varius sollicitudin. Sed ut dolor nec orci tincidunt interdum. Phasellus ipsum.
      Nunc tristique tempus lectus.</p>
  </div>
  <div id="tabs-2">
    <p>Morbi tincidunt, dui sit amet facilisis feugiat, odio metus gravida ante, ut pharetra massa metus id nunc. Duis scelerisque molestie turpis. Sed fringilla, massa eget luctus malesuada, metus eros molestie lectus, ut tempus eros massa ut dolor. Aenean
      aliquet fringilla sem. Suspendisse sed ligula in ligula suscipit aliquam. Praesent in eros vestibulum mi adipiscing adipiscing. Morbi facilisis. Curabitur ornare consequat nunc. Aenean vel metus. Ut posuere viverra nulla. Aliquam erat volutpat.
      Pellentesque convallis. Maecenas feugiat, tellus pellentesque pretium posuere, felis lorem euismod felis, eu ornare leo nisi vel felis. Mauris consectetur tortor et purus.</p>
  </div>
  <div id="tabs-3">
    <p>Mauris eleifend est et turpis. Duis id erat. Suspendisse potenti. Aliquam vulputate, pede vel vehicula accumsan, mi neque rutrum erat, eu congue orci lorem eget lorem. Vestibulum non ante. Class aptent taciti sociosqu ad litora torquent per conubia
      nostra, per inceptos himenaeos. Fusce sodales. Quisque eu urna vel enim commodo pellentesque. Praesent eu risus hendrerit ligula tempus pretium. Curabitur lorem enim, pretium nec, feugiat nec, luctus a, lacus.</p>
    <p>Duis cursus. Maecenas ligula eros, blandit nec, pharetra at, semper at, magna. Nullam ac lacus. Nulla facilisi. Praesent viverra justo vitae neque. Praesent blandit adipiscing velit. Suspendisse potenti. Donec mattis, pede vel pharetra blandit, magna
      ligula faucibus eros, id euismod lacus dolor eget odio. Nam scelerisque. Donec non libero sed nulla mattis commodo. Ut sagittis. Donec nisi lectus, feugiat porttitor, tempor ac, tempor vitae, pede. Aenean vehicula velit eu tellus interdum rutrum.
      Maecenas commodo. Pellentesque nec elit. Fusce in lacus. Vivamus a libero vitae lectus hendrerit hendrerit.</p>
  </div>
</div>

所以现在我们有 1 秒(1000 毫秒)的间隔,我们每秒增加一个计数器 c。一旦与数组中的触发时间相匹配,我们就切换到下一个选项卡。一旦我们到达数组中最后一个元素之后的某个点,我们就会重复或停止。

希望对您有所帮助。