如何使用Tab键移入下一个选项卡

时间:2013-12-31 14:16:25

标签: javascript jquery html asp.net css

我想在用户使用Tab键移入下一个标签时创建功能。每个选项卡都包含一些文本框。当用户在选项卡1的最后一个文本框中按Tab键时,它将进入tab2的下一个文本框。我使用普通的htlm css和jquery来制作标签。我没有使用jquery的标签功能。以下是我的HTML。我正在使用ul an li创建选项卡。当我的标签放在第一个文本框中时,我如何进入下一个li

HTML

 <ul class='tabs'>
        <li><a href='#tab1'>Tab 1</a></li>
        <li><a href='#tab2'>Tab 2</a></li>
        <li><a href='#tab3'>Tab 3</a></li>
      </ul>
      <div id='tab1'>
        <ul class= "set2"> 
            <li>  test 1<asp:TextBox runat="server"  ID="test1" /></li>
            <li>  test 2<asp:TextBox runat="server"  ID="test2" /></li>
        </ul>
      </div>
      <div id='tab3'>
        <ul class= "set2"> 
            <li>  test 3<asp:TextBox runat="server"  ID="test3" /></li>
            <li>  test 4<asp:TextBox runat="server"  ID="test4" /></li>
        </ul>
      </div>
      <div id='tab3'>
        <ul class= "set"> 
            <li>  test 5<asp:TextBox runat="server"  ID="test5" /></li>
            <li>  test 6<asp:TextBox runat="server"  ID="test6" /></li>
        </ul>
      </div>

这是jquery

// Wait until the DOM has loaded before querying the document
    $(document).ready(function(){
        $('ul.tabs').each(function(){
        // For each set of tabs, we want to keep track of
        // which tab is active and it's associated content
        var $active, $content, $links = $(this).find('a');

        // If the location.hash matches one of the links, use that as the active tab.
        // If no match is found, use the first link as the initial active tab.
        $active = $($links.filter('[href="'+location.hash+'"]')[0] || $links[0]);
        $active.addClass('active');
        $content = $($active.attr('href'));

        // Hide the remaining content
        $links.not($active).each(function () {
        $($(this).attr('href')).hide();
    });

        // Bind the click event handler
        $(this).on('click', 'a', function(e){
        // Make the old tab inactive.
        $active.removeClass('active');
        $content.hide();

        // Update the variables with the new link and content
        $active = $(this);
        $content = $($(this).attr('href'));

        // Make the tab active.
        $active.addClass('active');
        $content.show();

        // Prevent the anchor's default click action
        e.preventDefault();
    });
     });
  });
            </script>

和这个css

    * {padding:0; margin:0;}

    html {
        background:url(/img/tiles/wood.png) 0 0 repeat;
        padding:15px 15px 0;
        font-family:sans-serif;
        font-size:14px;
    }

    p, h3 { 
        margin-bottom:15px;
    }

    div {
        padding:10px;
        width:600px;
        background:#fff;
    }

    .tabs li {
        list-style:none;
        display:inline;
    }

    .tabs a {
        padding:5px 10px;
        display:inline-block;
        background:#666;
        color:#fff;
        text-decoration:none;
    }

    .tabs a.active {
        background:#fff;
        color:#000;
    }

1 个答案:

答案 0 :(得分:1)

使用此javascript:

Demonstration.

// Wait until the DOM has loaded before querying the document
$(document).ready(function () {
    $('ul.tabs').each(function () {
        // For each set of tabs, we want to keep track of
        // which tab is active and it's associated content
        var $active, $content, $links = $(this).find('a');

        // If the location.hash matches one of the links, use that as the active tab.
        // If no match is found, use the first link as the initial active tab.
        $active = $($links.filter('[href="' + location.hash + '"]')[0] || $links[0]);
        $active.addClass('active');
        $content = $($active.attr('href'));

        // Hide the remaining content
        $links.not($active).each(function () {
            $($(this).attr('href')).hide();
        });

        // Bind the click event handler
        $(this).on('focus', 'a', function (e) { //from click handler to focus handler
            // Make the old tab inactive.
            $active.removeClass('active');
            $content.hide();

            // Update the variables with the new link and content
            $active = $(this);
            $content = $($(this).attr('href'));

            // Make the tab active.
            $active.addClass('active');
            $content.show();

            // Prevent the anchor's default click action
            e.preventDefault();
        });
    });
});

这个HTML:

<ul class='tabs'>
    <li><a href='#tab1' tabindex="1">Tab 1</a> <!--tabindex added so that it could be accessed by pressing tab key-->

    </li>
    <li><a href='#tab2' tabindex="2">Tab 2</a> <!--tabindex added so that it could be accessed by pressing tab key-->

    </li>
    <li><a href='#tab3' tabindex="3">Tab 3</a> <!--tabindex added so that it could be accessed by pressing tab key-->

    </li>
</ul>
<div id='tab1'>
    <ul class="set2">
        <li>test 1
            <asp:TextBox runat="server" ID="test1" />
        </li>
        <li>test 2
            <asp:TextBox runat="server" ID="test2" />
        </li>
    </ul>
</div>
<div id='tab3'>
    <ul class="set2">
        <li>test 3
            <asp:TextBox runat="server" ID="test3" />
        </li>
        <li>test 4
            <asp:TextBox runat="server" ID="test4" />
        </li>
    </ul>
</div>
<div id='tab3'>
    <ul class="set">
        <li>test 5
            <asp:TextBox runat="server" ID="test5" />
        </li>
        <li>test 6
            <asp:TextBox runat="server" ID="test6" />
        </li>
    </ul>

代码说明

JS的解释:

我已将事件处理程序从click更改为focus,这样当div被聚焦时,脚本可以运行而不是点击它。

HTML说明:

我已将tabindex添加到标签中,以便可以使用标签键访问它们。