gpt4 book ai didi

空格的 JavaScript 验证

转载 作者:太空宇宙 更新时间:2023-11-03 18:44:29 26 4
gpt4 key购买 nike

我正在用 JavaScript 进行客户端验证。我可以对必填字段和电话号码字段进行验证,但除电子邮件字段外,所有其他字段都接受空格,以便验证通过并创建新的数据行。如何使用 JavaScript 在我的代码中包含空格验证?

JavaScript:

function form_validate(){
var error = 0;
var emailReg = /^([\w-\.]+@([\w-]+\.)+[\w-]{2,4})?$/;
$('#form input[type=text]').each(function(n,element){
$(this).removeClass('warning');
if ($(element).val()=='') {
$("#warning td").text("All fields are mandatory.");
$(this).addClass('warning');
$("#warning").show();
error++;
}else if($(element).attr('name')=='email'){
if (!emailReg.test($(element).val())){
$("#warning td").text("Enter a valid email address.");
$(this).addClass('warning');
$("#warning").show();
error++;
}
}else if(($(element).attr('name')=='phone' || $(element).attr('name')=='mobile') && error==0){
if (isNaN($(element).val())){
$("#warning td").text("Enter valid phone number.");
$(this).addClass('warning');
$("#warning").show();
error++;
}
}
});
if(error){
return false;
}else{
return true;
}
}

HTML

<table  width="100%">
<tr>
<td style="width:100px;">First name:</td><td><input type="text" name="first_name" id="first_name" maxlength="20"/></td>
</tr>
<tr>
<td style="width:100px;">Last name:</td><td><input type="text" name="last_name" id="last_name" maxlength="20"/></td>
</tr>
<tr>
<td>Email:</td><td><input type="text" name="email" maxlength="36" id="email"/></td>
</tr>
<tr>
<td>Daytime phone:</td><td><input type="text" name="phone" maxlength="15" id="phone_no" /></td>
</tr>
<tr>
<td>Mobile phone:</td><td><input type="text" name="mobile" maxlength="15" id="mobile" /></td>
</tr>
<tr style="display:none;color:red" id="warning">
<td colspan="2" align="center" >All fields are mandatory</td>
</tr>
</table>

最佳答案

请看http://jsfiddle.net/2W6fk/3/

       function form_validate(){
var error = 0;
var emailReg = /^([\w-\.]+@([\w-]+\.)+[\w-]{2,4})?$/;
var mobile_no_length = $('#mobile').val().trim().length
$(".text_field").each(function(n,element){
$(this).removeClass('warning');
if ($(element).val().trim().length < 1) {
$("#warning td").text("All fields are mandatory.");
$(this).addClass('warning');
$("#warning").show();
error++;
}else if($(element).attr('name')=='email'){
if (!emailReg.test($(element).val())){
$("#warning td").text("Enter a valid email address.");
$(this).addClass('warning');
$("#warning").show();
error++;
}
}else if(mobile_no_length < 1){
if (isNaN($(element).val())){
$("#warning td").text("Enter valid phone number.");
$(this).addClass('warning');
$("#warning").show();
error++;
}
}

});
if(error){
return false;
}else{
return true;
}
}

$('input[type=button]').on("click",function(){
form_validate();
});

$("#mobile, #phone_no").on("keyup", function(event) {
var limitField = $(this).val().trim().length;
var limit = "12"
this.value = this.value.replace(/[^0-9_\-\.]/g, '');
var id = $(this).attr('id')
if (limitField > limit) {
$("#"+id).val($(this).val().trim().substring(0, limit));
}
});

注意:除了电子邮件和电话,我添加了 text_field 类。现在我正在验证这两个 #mobile、#phone_no。现在您不能在该字段中键入字符(您只能键入整数)。然后我允许电话号码 最多 12 位数字。请根据您的要求进行更改。如果您不想验证 #phone_no,请从验证中删除。

我是否错过了任何其他验证?

关于空格的 JavaScript 验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16713664/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com