利用jquery实现在html的表格中使用上下左右键切换单元格,同时只限制单元格输入数字

本文介绍了一种利用JavaScript为HTML表格中的单元格设置TabIndex的方法,并确保按照特定顺序进行焦点移动。同时,实现了对表格中输入框的数字输入限制功能。

因其他无关代码比较多,只贴关键代码,请谅解。

解释:

tblGrid是表格的id ,<pre name="code" class="html">onchange是每个单元格都拥有的方法,当然可以根据实际情况更改
flag是标志位,保证按照我想要的顺序新增tabindex

<script type="text/javascript">
    $(function() {
        var baseIndex = 100;
		var flag=1;
		$("#tblGrid").find("tr").each(function(r) {		
			
			if($(this).find("[onchange]").length >0){
				  $(this).find("[onchange]").each(function(c) {
						$(this).attr("tabindex", flag * 100 + c + baseIndex);
						
					});
				flag++;
			}    
			
        });
		
      });
</script>


<pre name="code" class="html">/**
			控制input框 限制只能输入数字
		*/
		function check(event) {  
				  var e = window.event || event;  	
				  var target = e.srcElement || e.target;  
				  var tabIndex=target.tabIndex;
				  var className=target.className;
				  var k = e.keyCode;  
				  if(isFunKey(k,tabIndex)) {  
					return true;  
				  }  
				  var c = getChar(k);  
				  if(target.value.length == '' && (c == '-' || c == '+')) {  
					return true;  
				  }  
				  if(isNaN(target.value + getChar(k))) {  
					return false;  
				  }  
				  return true;  
				}  
				  
		function isFunKey(code,tabIndex) {  
				  //  8 --> Backspace  
				  //  9 --> tab  
				  // 35 --> End  
				  // 36 --> Home  
				  // 37 --> ←
				  // 38 --> ↑
				  // 39 --> →
				  // 40 --> ↓ 
				  // 46 --> Delete  
				  // 112~123 --> F1~F12  
				  var funKeys = [8,9, 35, 36, 37,38, 39,40, 46];  
				  for(var i = 112; i <= 123; i++) {  
					funKeys.push(i);  
				  } 
				  
				  for(var i = 0; i < funKeys.length; i++) {  
					if(funKeys[i] == code) {
						
						if(funKeys[i]==38){
							tabIndex -= 100;	
							  $("input[tabindex=" + tabIndex + "]").focus();
							  return false;
						}else if(funKeys[i]==40){
							tabIndex += 100;
							 $("input[tabindex=" + tabIndex + "]").focus();
							  return false;
						}else if(funKeys[i]==37){
							  tabIndex--;
							 $("input[tabindex=" + tabIndex + "]").focus();
							  return false;
						}else if(funKeys[i]==39){
							tabIndex++;
							 $("input[tabindex=" + tabIndex + "]").focus();
							  return false;
						}						
								  
					  return true;  
					}  
				  }  
				  return false;  
				} 





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值