Javascript:如何检查每个输入值是否重复到另一个输入值

标签 javascript jquery html arrays

所以我有一个动态输入字段来自具有不同类名和名称的追加,我想检查每个输入字段值是否已经存在或重复。

这看起来像

第一个 criteria_name 是默认的,其他的是附加的。

<input type="text" name="criteria_name" class="criteria_name">
<input type="text" name="criteria_name2" class="criteria_name2">
<input type="text" name="criteria_name3" class="criteria_name3">
<input type="text" name="criteria_name4" class="criteria_name4">
<input type="text" name="criteria_name5" class="criteria_name5">

如果没有重复,我会尝试检查每一个。

 var critname_arr = [];
 var input_check;
 var crit_name_of_first = $('input.criteriaNames').val();
 var acappended = append_crit_header+1;
 var count_to = 0;

 for(var ab = 2; ab<=acappended; ab++){
      var crit_arr;

    if(crit_name_of_first == $('input.criteria_each_name'+ab+'').val()){
        alert("Criteria cannot be duplicate");
        return false;
    }else{

        input_check = $('input.criteria_each_name'+ab);
        input_check.each(function(){
            crit_arr = $.trim($(this).val());           
        });
        critname_arr.push(crit_arr);
    }
    if($('input.criteria_each_name'+ab+'').val() == critname_arr[count_to]){
            alert('criteria cannot be duplicate');
            return false;
    }
    count_to++;
}
console.log(critname_arr);

最佳答案

这只是您如何做到这一点的一个例子。在 fiddle 中,将其中一个值更改为另一个字段中已经存在的值(创建重复值)以查看它是否执行某些操作。如果没有重复项,它将不会执行任何操作。单击“按钮”文本以运行重复检查:

jsFiddle: https://jsfiddle.net/o52gjj0u/

<script>
$(document).ready(function(){
    $('.ter').click(function(e) {
        var stored  =   [];
        var inputs  =   $('.criteria_name');
        $.each(inputs,function(k,v){
            var getVal  =   $(v).val();
            if(stored.indexOf(getVal) != -1)
                $(v).fadeOut();
            else
                stored.push($(v).val());
        });
    });
});
</script>
<!-- Just use an array name for the input name and same class name as well -->
<div class="ter">Button</div>
<input type="text" name="criteria_name[]" class="criteria_name" value="1" />
<input type="text" name="criteria_name[]" class="criteria_name" value="2" />
<input type="text" name="criteria_name[]" class="criteria_name" value="3" />
<input type="text" name="criteria_name[]" class="criteria_name" value="4" />
<input type="text" name="criteria_name[]" class="criteria_name" value="5" />

关于Javascript:如何检查每个输入值是否重复到另一个输入值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38800052/

相关文章:

javascript - jQuery 和 AngularJS 不能一起工作

javascript - 使用 wheel event a increments 遍历数组

javascript - JS/Jquery 和 firebase 登录页面问题

javascript - 如何删除jquery中的选项值

javascript - 一旦列表中的所有 "complete"函数都完成,就执行代码

css - 从下到上堆叠 div

javascript - js的xul容器函数,我想从页面上的外部iframe调用js函数之一

javascript - 无法切换多个 div 的可见性,因为切换()分别跟踪每个元素

jquery - 如何将div放入文本框

javascript - 无法实现 mustache js 来显示信息