jquery验证手机号是否正确实例讲解
如果要做手机号的验证,那么我们需要知道手机号码的号段。
//移动号码归属地支持号段:134135136137138139147150151152157158159178 182183184187188
//联通号码归属地支持号段:130131132 145155156176 186
//电信号码归属地支持号段:133153177180181189
//移动运营商:170
移动:
2G号段(GSM):134-139、150、151、152、158-159;
3G号段(TD-SCDMA):157、187、188、147.
联通:
2G号段(GSM):130-132、155-156;
3G号段(WCDMA):185、186.
电信:
2G号段(CDMA):133、153;
3G号段(CDMA2000):180、189.
可以写出一个正则表达式:varmyreg=/^(((13[0-9]{1})|(14[0-9]{1})|(17[0]{1})|(15[0-3]{1})|(15[5-9]{1})|(18[0-9]{1}))+\d{8})$/;
<inputtype="text"id="phone"name="phone"/>
首先引入一个JQuery框架:
<scriptsrc="http://ajax.aspnetcdn.com/ajax/jQuery/jquery-1.8.0.js"> </script>
校验手机号的函数:
//验证手机号
functionvailPhone(){
varphone=jQuery("#phone").val();
varflag=false;
varmessage="";
varmyreg=/^(((13[0-9]{1})|(14[0-9]{1})|(17[0]{1})|(15[0-3]{1})|(15[5-9]{1})|(18[0-9]{1}))+\d{8})$/;
if(phone==''){
message="手机号码不能为空!";
}elseif(phone.length!=11){
message="请输入有效的手机号码!";
}elseif(!myreg.test(phone)){
message="请输入有效的手机号码!";
}elseif(checkPhoneIsExist()){
message="该手机号码已经被绑定!";
}else{
flag=true;
}
if(!flag){
//提示错误效果
//jQuery("#phoneDiv").removeClass().addClass("ui-form-itemhas-error");
//jQuery("#phoneP").html("");
//jQuery("#phoneP").html("<iclass=\"icon-errorui-margin-right10\"> <\/i>"+message);
//jQuery("#phone").focus();
}else{
//提示正确效果
//jQuery("#phoneDiv").removeClass().addClass("ui-form-itemhas-success");
//jQuery("#phoneP").html("");
//jQuery("#phoneP").html("<iclass=\"icon-successui-margin-right10\"> <\/i>该手机号码可用");
}
returnflag;
}
发送请求给后台:
//验证手机号是否存在
functioncheckPhoneIsExist(){
varphone=jQuery("#phone").val();
varflag=true;
jQuery.ajax(
{url:"checkPhone?t="+(newDate()).getTime(),
data:{phone:phone},
dataType:"json",
type:"GET",
async:false,
success:function(data){
varstatus=data.status;
if(status=="0"){
flag=false;
}
}
});
returnflag;
}
java后端进行校验:
@RequestMapping(value="/checkPhone",method=RequestMethod.GET)
publicvoidcheckPhone(HttpServletRequestrequest,HttpServletResponseresponse){
Map<String,Object>map=newHashMap<String,Object>();
try{
Stringphone=request.getParameter("phone");
Stringstatus="0";
//写查询逻辑,查出有的话,那么标记为1,否则标记为0
//UserCellphoneAuthuserCellphoneAuth=userService.findUserCellphoneAuthByPhone(phone);
//if(userCellphoneAuth!=null){
//status="1";
//}
map.put("status",status);
Stringdata=JSONObject.fromObject(map).toString();
response.getWriter().print(data);
response.getWriter().flush();
response.getWriter().close();
}catch(Exceptionex){
logger.error(ex.getMessage(),ex);
}
}
以上就是本文的全部内容,教大家如何进行jquery验证手机号是否正确,利用正则表达式,大家可以动手试一试。