如何防止javascript中的重复条目?

时间:2012-03-09 01:59:06

标签: javascript jquery

我在防止输入重复项方面存在问题,我只使用一个按钮同时动态生成两个页面中的单选按钮,我从用户处获取标签并从该标签生成单选按钮,i想阻止用户输入2个相同的标签,这里是为2页生成无线电的脚本,任何帮助都将受到赞赏

function createRadioElement(elem, label, checked) {
var id = 'option1_' + label;
$('#after').append($('<input />', {
    'type': 'radio',
    'fieldset':'group',
    'name': 'option1',
    'id': id,
    'data-role': 'controlgroup',
    'data-theme':'b',
    'value': '1'}));
$('#after').append('<label for="' + id + '">'+ label + '</label>').trigger('create');}

function createRadioFortSecondPage(elem, label, checked) {
var id = 'option1_' + label;
$('#Inserthere').append($('<input />', {
    'type': 'radio',
    'fieldset':'group',
    'name': 'option1',
    'id': id,
    'data-role': 'controlgroup',
    'data-theme':'b',
    'value': '1'}));
$('#Inserthere').append('<label for="' + id + '">'+ label + '</label>').trigger('create');}

这是我写的用来防止重复的功能:

function checkDublicates(){
     var isExist=true;
     var x = document.getElementById('option').value;
     var labels = [];   
$('#after input[type=radio]').each(function() {
     labels.push($('label[for='+$(this).attr('id')+']').text());


    });
    for(var i=0;i<labels.length;i++){

    if(x==labels[i])
    {
        isExist=false;}
        else{
        isExist=true;}
      }
    return isExist;}

这就是按钮操作:

$('#AddButton').click(function(){
     var exist=checkDublicates();
     <!--var isEmpty=validate();-->
    <!--if(exist==true){
        <!--alert("Duplicates Are Not Allowed!");
        <!--}else{
    var y=document.getElementById('question').value
    document.getElementById('headTitle').innerHTML=y;
    if(exist==false){
        alert("Duplicates Not Allowed!")
    }else{
    createRadioElement(this,$('#option').val(),true);
    createRadioFortSecondPage(this,$('#option').val(),true);
  }

  });

3 个答案:

答案 0 :(得分:2)

只需使用$.inArray(val, arr)即可使用! http://api.jquery.com/jQuery.inArray/

但只是关于你的代码的评论。

替换

document.getElementById('question').value

通过

$('#question').val()

document.getElementById('headTitle').innerHTML=y

通过

$('#headTitle').html(y)

会更清洁; - )

答案 1 :(得分:1)

您可以使用此便捷功能将元素推入数组并同时检查重复项。如果它捕获重复,它将返回true

var noDupPush = function (value, arr) {

    var isDup = false;

    if (!~$.inArray(value, arr)) {
        arr.push(value);
    } else {
        isDup = true;
    }

    return isDup;

};

// You can use it like this

var arr = ['green'];
if (noDupPush('green', arr)){
  // Dup exists
}
// Or else it will just push new value to array

答案 2 :(得分:1)

您可以生成包含标签文本的ID,然后快速检查是否存在包含该文本的元素。例如:

function generateLabelId( userinput ){ 
    return 'awesomelabel_' + userinput.replace(/\W/g,'');
}

var label = document.getElementById(generateLabelId( userinput ));
var labelDoesNotExist = (label == undefined );

if (labelDoesNotExist){
    // create your element here
    // making sure that you add the id from generateLabelId
}