gpt4 book ai didi

javascript - 如何使用tab键进入下一个标签

转载 作者:行者123 更新时间:2023-11-28 17:58:46 25 4
gpt4 key购买 nike

我想创建当用户使用 Tab 键移动到下一个选项卡时的功能。每个选项卡都包含一些文本框。当用户在选项卡 1 的最后一个文本框中按下 Tab 键时,它将进入选项卡 2 的下一个文本框。我正在使用普通的 html 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;
}

最佳答案

使用这个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 添加到选项卡,以便可以使用 tab 键访问它们。

关于javascript - 如何使用tab键进入下一个标签,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20858705/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com