2013-01-23 64 views
0

我忙於爲這個可複製字段創建驗證,所以如果在輸入'Name'和'Surname'中沒有填充任何內容,則模糊,那麼錯誤消息將會顯示出來,唯一的問題是錯誤顯示了輸入'姓名'和'姓氏',而不是一個。jquery驗證顯示2個div的錯誤,而不是一個

請記住,底部字段是可複製的,驗證必須爲他們工作,因此爲什麼代碼是按原樣寫入的。

任何幫助非常感謝。

JsFiddle

和JavaScript:

//Error Messages 
var messages = { 
    "main_name general": "no main name", 
}; 
var g_counter = 1; 
var dependant = ["dependant"]; 
var group; 
var name_input_groups = ["name-group-1"]; 
var surname_input_groups = ["surname-group-1"]; 
var input_groups = ["group-1"]; 

var name_fields=[0]; 
var name_input = "<input class='name' name='name' data-error='Please enter a Dependant name' type='text' />"; 
var surname_input = "<input id='surname' class='surname' name='surname' type='text' data-error='Surname error' />"; 

jQuery(document).ready(function(e) { 
    jQuery(name_fields).each(function() { 
     jQuery(name_input).appendTo('#name-group-1'); 
    }); 
    jQuery(name_fields).each(function() { 
     jQuery(surname_input).appendTo('#surname-group-1'); 
    }); 

    jQuery('#clone').click(function() { 
     clone_dependant(); 
    }); 

    function clone_dependant() { 
     var oldId = g_counter; 
     g_counter++; 
     currentdep ='dependant-'+g_counter; 
     var $clonedDiv = jQuery('#dependant-1').clone(false).attr('id', currentdep); 
     var name_newDiv = 'name-group-'+ g_counter; 
     var surname_newDiv = 'surname-group-'+ g_counter; 
     // Find div's inside the cloned object and set a new id's 
     $clonedDiv.find('#name-group-1').attr('id',"name-group-" + g_counter); 
     $clonedDiv.find('#surname-group-1').attr('id',"surname-group-" + g_counter); 
     $clonedDiv.find('#dep_num').html(g_counter); 
     // Insert the cloned object 
     $clonedDiv.insertAfter("#dependant-" + oldId); 
     name_input_groups.push(name_newDiv); 
     surname_input_groups.push(surname_newDiv); 
    } 
/////////////////////////////////////////// 
//VALIDATION 
////////////////////////////////////////// 
$('.name').after('<div class="error"></div>'); 
$('.surname').after('<div class="error"></div>'); 
$('.error').hide(); 

////Validate Surname 
$(document).on('blur keyup', 'input.surname', function(e) { 
    validate_Surname_Input(this); 
}); 


function validate_Surname(surname_values, el){ 
    var error_message = $(el).find('input').data('error'); 
    if (surname_values.length > 0) { 
     $(el).find('.error').slideUp('slow'); 
     return true; 
    }else { 
     $(el).find('.error').html(error_message).slideDown('slow'); 
     console.log($(el).find('.error')); 
     return false; 
    } 
}; 

function validate_Surname_Input(el) { 
    var $this = $(el); 
    var input_groups = $this.parent(); 
    var isValid = true; 
    $.each(input_groups , function(i){ 
     var inpg = input_groups[i]; 
     surname_values = $.map($(inpg).children('input'), function(e,i){ 
      return $(e).val(); 
     }).join(''); 
     isValid = isValid && 
      validate_Surname(surname_values, input_groups.parent().parent().parent(), el); 
    }); 
    return isValid; 
} 
////Validate Surname 

////Validate Name 
$(document).on('blur keyup', 'input.name', function(e) { 
    var values = $(this).val().length; 
    validate_Name_Input(this); 
}); 


function validate_Name(name_values, el){ 
    var error_message = $(el).find('input').data('error'); 
    if (name_values.length > 0) { 
     $(el).find('.error').slideUp('slow'); 
     return true; 
    }else { 
     $(el).find('.error').html(error_message).slideDown('slow'); 
     return false; 
    } 
}; 

function validate_Name_Input(el) { 
    var $this = $(el); 
    var input_groups = $this.parent(); 
    var isValid = true; 
    $.each(input_groups , function(i){ 
     var inpg = input_groups[i]; 
     name_values = $.map($(inpg).children('input'), function(e,i){ 
      return $(e).val(); 
     }).join(''); 
     isValid = isValid && 
      validate_Name(name_values, input_groups.parent().parent().parent(), el); 
    }); 
    return isValid; 
} 
////Validate Name 

/////////////////////////////////////////// 
//VALIDATION 
///////////////////////////////////////// 
var result = {}; 
var dependants; 
var mainmember; 
var dep_counter = 0; 
function getValues(){ 
    jQuery('div[class*="mainmember"]').each(function(k, v){ 
     mainmember = {}; 
     mainmember['name'] = $(v).find('.name').val(); 
     mainmember['surname'] = $(v).find('.surname').val(); 
     result['mainmember'] = mainmember; 
    }); 

    result['dependants'] = []; 
    jQuery('div[class*="dependant"]').each(function(k, v){ 
     dep_counter++ 
     dependants = {}; 
     dependants['name'] = $(v).find('.name').val(); 
     dependants['surname'] = $(v).find('.surname').val(); 
     result['dependants'].push(dependants); 
    }); 
}; 

var isValid = true; 

jQuery('#submit').click(function(){ 
var isValid = true; 
    $('input.name').each(function(i, el) { 
     isValid = isValid && 
      validate_Name_Input(el); 
    }); 
if (isValid) { 
    getValues(); 
    var jsonData = JSON.stringify(result); 
    jQuery.ajax({ 
     type: "POST", 
     url: "mail.php", 
     dataType: "json", 
     beforeSend: function() { 
     }, 
     data: {parameters: jsonData} 
    }); 
    } else { 
     console.log('send fail'); 
    } 
}); 

}); 

和HTML:

<div id="app_wrap"> 
<!--Main Member--> 
    <div class="title">personal information of principal member:</div> 
    <div class="mainmember" id="mainmember" > 
    <!--Level 1--> 
      <div class="block_wrap left border_right"> 
       <div class="block">surname:<div class="right"><input class="surname" data-error="Please enter a Surname" /></div></div> 
     </div> 

     <div class="block_wrap right"> 
       <div class="block">full name:<div class="right"><input class="name" data-error="Please enter a Main member Name" /></div></div> 
     </div> 

    <!--Level 1--> 
    </div> 
<!--Main Member--> 

<!--Dependant--> 
    <div class="dependant-1" id="dependant-1"> 
    <div class="title">dependant <span id="dep_num">1</span>:</div> 
    <div id="dependant"> 
    <div class="block_wrap left border_right"> 
      <div class="block">surname:<div id="surname-group-1" class="right"></div></div> 
    </div> 
    <!--Level 1--> 
    <div class="block_wrap right"> 
      <div class="block">full name:<div id="name-group-1" class="right"></div></div> 
    </div> 
    <!--Level 1--> 
    </div> 
    </div> 
<!--Dependant--> 
    <button id="clone">Add a Dependant</button> 
    <button id="submit">submit</button> 
    </div> 
</div> 
+0

我想有一個的參考輸入一個問題。我正在調查它。只是掛在:) –

+0

我很不確定你在做什麼。你的JS對於你試圖實現的東西感覺相當巨大,特別是考慮到你正在使用jQuery。你能否提供更多關於預期產出的信息?根據你對問題的解釋,我覺得'validate_Name(name_values,input_groups.parent()。parent()。parent(),el);'是什麼錯誤,你需要2個父母,而不是3個。 – Khez

+0

@Khez I也認爲同樣的JS和其他的東西本來可能會少一點Dawin試圖實現的東西...... :( –

回答

2

看到這個:http://jsfiddle.net/6QTyd/5/

還要注意這些方面的變化:

validate_Surname(surname_values, input_groups.parent().parent()); 

validate_Name(name_values, input_groups.parent().parent()); 
+0

它沒有' t似乎是驗證受撫養人姓氏 –

+0

是的,它確實...你能告訴現在的問題是什麼..? – Anujith

+0

我認爲我修好了,抱歉不是你的錯:我只是用點擊取代了var isValid = true ; $ ('input.name,input.surname')。each(function(i,el){validate_Surname_Input(el);};}};}}}。 }); –

相關問題