问题背景
点击表格中的多行,通过填写表单号,来进行后续的操作。。。
在我们填写表单号时,如何才能避免填入的表单号重复呢?
还有一个问题,在去除重复时,我们必须判断比较重复的行不是自身。
其实在解决这个问题时,最开始,我以最普通的思维来解决:
顺序思维
我所指的是一条一条添加,也就是按顺序填写。这个时候,每次在判断时,只需要判断最后一条与前面的所有信息,只要没有重复即可认为不存在重复信息了? 到这里,你是否认为这样正确呢?
先按照这样解决,看一下我的解决方案:
var count=0;
jq("input[itemvarname='item100'][itembilltype='2']").each(function(){
count++;
})
jq("input[itemvarname='item100'][itembilltype='2']").each(function(i,object){
if(i !=count-1){
if(object.value==billNumber){
alert("输入的单据号已经存在,请重新输入!");
obj.val("");
return
}
}
})
这样做的核心是:只需要计算出总共的条数,这样我就可以判断出当前填的最后一条数据是第几条数据,这样只要将这条数据与之前的所有数据进行比较,没有重复即可。
听起来似乎已经很完美了,不是吗?
打破常规
后来,我忽然想到,假如,我现在全部填完了,但是忽然想要该其中的一个,也许就是改的第一个,或者第二个。。。这个可不一定哦?这个时候怎么办?之前的那种想法可就不成立了。
如果利用上面那种思维,通过个数来标记已经很不现实了,所以这次,我用了flag来进行标记。具体解决方案如下:
var flag=0;
jq("input[itemvarname='item100'][itembilltype='2']").each(function(i,object){
if(billNumber==object.value){
flag=i;
}
})
jq("input[itemvarname='item100'][itembilltype='2']").each(function(i,object){
if(flag !=i && object.value==billNumber){
alert("输入的单据号已经存在,请重新输入!");
obj.val("");
obj.parent().siblings().find("input[itemvarname='item46'][itembilltype='2']").attr({value:""});
obj.parent().siblings().find("input[itemvarname='item115'][itembilltype='2']").attr({value:""});
return
}
})
通过做标记来解决赋值重复问题。当然这种解决方法有它的局限性,不知道你看出来了没啊?但是却很适合我的这种环境哦。
局限性:由于多次被标记会导致flag被覆盖,所以这种避免重复的方式只适合最多可能存在一次重复的情况。