我已经在我的JSP页面中的所有元素上确定了选项卡索引,但是在选项卡索引流程中,浏览器的功能也得到了集中。
实施例: 当标签焦点位于我页面的最后一个元素上时,如果我再次点击标签,则焦点将转到浏览器的地址栏,刷新按钮,标签窗口和主页按钮。
我希望焦点应该放在第一个元素上,该元素在最后一个标签索引10之后有标签索引1。
如何从标签聚焦中限制这些浏览器功能。我正在使用Javascript / JQuery和IE 9。
以下是我的页面:
<html>
<body>
<script src="jquery.js"></script>
<script type="text/javascript">
$(document).ready(function() {
//functions
});
</script>
<div id="xyz">
<ul >
<li>
<div>
<input type="text" maxlength="30" tabindex = "1" />
<br>
<input type="text" maxlength="30" tabindex = "2" />
<br>
</div>
</li>
</ul>
<ul>
<li>
<div>
<input type="checkbox" id="checkBox1" value="false" tabindex ="3"/>
</div>
<div>
<input type="checkbox" id="checkBox2" value="false" tabindex ="4"/>
</div>
</li>
<li>
<div>
<input type="button" name="saveBtn" id="saveBtn" value="SaveMe" tabindex ="5"/>
</div>
<div>
<input type="button" name="clearBtn" id="clearBtn" value="ClearMe" tabindex ="6"/>
</div>
</li>
</ul>
</div>
</body>
</html>
答案 0 :(得分:2)
如果当前焦点是最后一个元素,您可以使用下面的脚本来聚焦第一个元素。
<input id="firstElement" value="" />
<!---series of dom element-->
<input id="lastElement" value="" />
<script>
$('#lastElement').keydown(function(e) {
if (e.keyCode == 9) {
$('#firstElement').focus();
e.preventDefault();
}
});
</script>
答案 1 :(得分:1)
您可以将keydown
事件与.index()
和.length
结合使用进行检查:
$('#xyz').find(':input').last().keydown(function(e) {
if ($(this).attr('tabindex') == $('#xyz').find(':input').length) {
if (e.keyCode === 9) {
e.preventDefault();
$('input[type="text"]').first().trigger('focus');
}
}
});
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="xyz">
<ul>
<li>
<div>
<input type="text" maxlength="30" tabindex="1" />
<br>
<input type="text" maxlength="30" tabindex="2" />
<br>
</div>
</li>
</ul>
<ul>
<li>
<div>
<input type="checkbox" id="checkBox1" value="false" tabindex="3" />
</div>
<div>
<input type="checkbox" id="checkBox2" value="false" tabindex="4" />
</div>
</li>
<li>
<div>
<input type="button" name="saveBtn" id="saveBtn" value="SaveMe" tabindex="5" />
</div>
<div>
<input type="button" name="clearBtn" id="clearBtn" value="ClearMe" tabindex="6" />
</div>
</li>
</ul>
</div>
&#13;