Jquery实现回车键Enter切换焦点{转}
系统默认情况下,使用Tab按键切换页面元素的焦点,有没有想过回车键Enter也可以实现这种功能,并且具有良好的用户体验。接下来我们使用Jquery实现回车键Enter切换焦点,此代码在常用浏览器IE7, IE8, Firefox 3, Chrome 2 和 Safari 4测试通过。???????? 使用的开发工具是微软VS2010+Jquery框架。实现步骤如下1、首先引用Jquery类库<script src="Scripts/jquery-1.4.1.min.js" type="text/javascript"></script>2、Javascript代码
?
??? <script type="text/javascript">??????? $(function () {??????? $('input:text:first').focus();??????? var $inp = $('input:text');??????? $inp.bind('keydown', function (e) {??????????? var key = e.which;??????????? if (key == 13) {??????????????? e.preventDefault();??????????????? var nxtIdx = $inp.index(this) + 1;??????????????? $(":input:text:eq(" + nxtIdx + ")").focus();??????????? }??????? });??? });??? </script>?
分析:$('input:text:first').focus();?? 页面初始化时,焦点定位第一个文本框内var $inp = $('input:text');??? 取的type=文本框的元素集合?
<div>??????? <asp:TextBox ID="txt1" runat="server" /><br />??????? <asp:TextBox ID="txt2" runat="server" /><br />??????? <asp:TextBox ID="txt3" runat="server" /><br />??????? <asp:TextBox ID="txt4" runat="server" /><br />??? </div>?
分析:页面上存放四个文本框3、运行程序
??那页面中如果有TextArea 元素,我们如何使用Enter切换焦点呢,办法是有的,如下充分运用了Jquery的一些特性。?4、HTML代码?
<div>??????? <asp:TextBox ID="tb1" runat="server" /><br />??????? <asp:TextBox ID="tb2" runat="server" /><br />??????? <asp:TextBox ID="tb3" TextMode="MultiLine" runat="server" /><br />??????? <asp:TextBox ID="tb4" runat="server" /><br />??? </div>?
分析:???????? 页面中所以的TextBox 引用Class=”cls”,便于后期的对页面元素的Jquery查询。?5、Javascript代码?
<script type="text/javascript">??????? $(function () {??????????? $('input:text:first').focus();??????????? var $inp = $('.cls');??????????? $inp.bind('keydown', function (e) {??????????????? var key = e.which;??????????????? if (key == 13) {??????????????????? e.preventDefault();??????????????????? var nxtIdx = $inp.index(this) + 1;??????????????????? $(".cls:eq(" + nxtIdx + ")").focus();??????????????? }??????????? });??????? });??? </script>?
分析:var $inp = $('.cls');?????????????????? 取的样式为cls的所有元素 赋值给变量inp6、运行效果