批量录入表格中回车事件处理

界面布局:

 脚本函数:

function transEnter(sender) {

            if (event.keyCode == 13) {
                var senderId = sender.getAttribute('id');
                var ptr = $("#" + senderId);//当前行
                var ptb = $("#" + senderId);//当前单元格
                while (ptr.get(0).tagName != "TR") {
                    ptr = ptr.parent();
                }
                while (ptb.get(0).tagName != "TBODY") {
                    ptb = ptb.parent();
                }
                //计算当前触发控件所在单元格索引
                var tdindex = 0;
                for (var i = 0; i < ptr.children('td').length; i++) {
                    var unknowobj = ptr.children('td').eq(i);
                    if(unknowobj.children(":text").length ==1)
                    {
                        var id = unknowobj.children(":text").attr('id');
                        if (id == sender.id) {
                            tdindex = i;
                            break;
                        }    
                    }
                    
                }
                console.log("tdindex",tdindex); //找到正确的tdindex            
                console.log("ptr.children('td').length",ptr.children('td').length);

                //获取当前单元格
                var unknowobj = ptr.children('td').eq(tdindex + 1);
            
                while(unknowobj.children(":text").length == 0)//判断当前单元格是否包含输入控件
                {
                    tdindex = tdindex + 1;
                    unknowobj = ptr.children('td').eq(tdindex + 1);//找下一个单元格
                    console.log(unknowobj.children(":text").length);
                    if(ptr.children('td').length == tdindex)//如果当前行的最后一个单元格已经检索完成
                    {
                        //更换行对象
                        if(ptr.index() + 1 < ptb.children('TR').length -1)//当前行不是最后一行
                        {
                            ptr = ptb.children('TR').eq(ptr.index() + 1);//切换下一行
                            tdindex = 0;//td从0开始
                            unknowobj = ptr.children('td').eq(tdindex);    //更换单元格
                        }
                        else{//全部行处理完成
                            break;
                        }                        
                    }
                }
                if(unknowobj.children(":text").length ==1){
                    var id = unknowobj.children(":text").attr('id');
                    console.log("obj.id", id);
                    unknowobj.children(":text").focus();
                }
                return false;            
            }           
            return true;
        }

//激发代码

"onkeydown", "return transEnter(this);"

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值