您的位置:首页 > Web前端

积跬步,聚小流------关于手机号,前端应该注意哪些

2015-08-17 14:12 531 查看
现代的网上商城中越来越多的开始使用手机注册,方便,快捷,然后作为前端,也就不可避免的要在界面上碰到关于手机号的问题,今天小小总结一下该注意哪些问题,又该来如何实现呢?

1、实现效果

先把自己当前做出来的效果传上来看下:



(备注:这里的手机号码是我随便输了一个,如果真有这个号码受到了骚扰,别怪我啊,噗噗...)

2、需要注意的问题

这里我们来简单罗列下需要注意的问题吧:

* input输入框,只能输入数字;
* 输入过程中下方同步显示所输入的内容;
* 判断输入手机号是否格式正确;
* 判断手机归属地;

3、实现步骤

1、页面结构

<div class="phone_num">
<label class="float_left">手机号码:</label>
<input type="text"
onkeyup="javascript:ckphone(this)"
onafterpaste="javascript:ckphone(this)"
onchange="javascript:ckphonelast(this)"
onblur="javascript:ckphonelast(this)" />
<div class="show_phone_num">
<span id="phone_showtip"><!--155 77777 6666--></span>
<span class="phone_from_where" id="phone_belong">
<!--(广西 中国联通)-->
</span>
</div>
</div>


2、样式

然后我们先假定存在默认的手机号和默认的手机归属地,获得上方的样式
.phone_num {
position: relative;
height: 50px;
line-height: 50px;
margin-bottom: 30px;
}
.phone_num input {
width: 300px;
height: 30px;
padding: 5px 5px;
float: left;
}
.phone_num span {
display: inline-block;
margin-left: 30px;
}
.show_phone_num {
width: 500px;
height: 40px;
line-height: 40px;
position: absolute;
left: 75px;
color: #ff5205;
font-size: 18px;
font-weight: bold;
bottom: -30px;
}
.phone_from_where {
display: inline-block;
font-size: 14px;
color: #000;
height: 30px;
line-height: 30px;
margin-left: 60px;
font-weight: 100;
position: relative;
}


3、对手机号的操作

通过结构代码我们可以简单发现我们相应的操作,比方说录入代码或者粘贴代码等等时
function ckphonelast(n){
if(n.value.length!=11){
$('#phone_showtip').html("请输入正确的手机号");
}else{
var partten = /^1[3,5,8]\d{9}$/;
if(partten.test(n.value)){
ckbelong(n.value);
}else{//正则判定不是手机号
$('#phone_showtip').html("请输入正确的手机号");
}
}
}
function ckphone(n){
$('#phone_showtip').html("");
$("#phone_belong").html("");
var ck=false;
n.value=n.value.replace(/\D/g,'');
if(n.value.length>11){       //只能录入11位数字
n.value=n.value.substring(0,11);
}
if(n.value.length<=3){      //为了显示时前面的表格
$('#phone_showtip').html(n.value);
}
if(n.value.length>3){
$('#phone_showtip').html(n.value.substring(0,3)).append(" ").append(n.value.substring(3));
}
if(n.value.length>7){
$('#phone_showtip').html(n.value.substring(0,3)).append(" ").append(n.value.substring(3,7)).append(" ").append(n.value.substring(7));
}
if(n.value.length==11){
var partten = /^1[3,5,8]\d{9}$/;
if(partten.test(n.value)){
ck=true;
}else{//正则判定不是手机号
$('#phone_showtip').html("请输入正确的手机号");
}
}
if(ck){
ckbelong(n.value);
}
}
这里简单解释下以上代码:
首先:用正则表达式来获取只能录入数字的时候,我们通常是这样做的:
<input type="text"
onkeyup="this.value=this.value.replace(/\D/g,'')"
onafterpaste="this.value=this.value.replace(/\D/g,'')" />
而在这里我们只是将this对象直接传递过来,然后进行操作。这样我们已经保证录入数据都为数字,我们就完成了第一步,然后进行第二步操作,同步录入信息。
我们首先观察录入信息和同步的显示的不同点,显示的时候是以3/4/4的格式进行显示的,中间以空格进行间隔,这样我们就要在操作的同时,在相应的位置添加空格。
第三:我们通过正则表达式来判定手机号格式是否正确,以保证你录入的数字是一个手机号,而不是你的银行卡密码。
最后,我在这里利用淘宝的接口来判定手机的归属地,当然如果真正用到项目中肯定要调用自己的接口,不过只用来显示的话,这也无可厚非啦。
function ckbelong(phone){
$.ajax({
type: "get",
url: 'http://tcc.taobao.com/cc/json/mobile_tel_segment.htm?tel='+phone,
dataType: "jsonp",
jsonp: "callback",
success: function(n){
$("#phone_belong").html(data.province+" "+data.catName);
},
error:function (data){
$("#phone_belong").html("该手机号存在问题");
}
});
}
我们来简单看下它的返回值都是什么呢?



这样我们就得到了相应的手机号码归属地啊,从而显示在界面上就可以了啦。

啦啦啦,这样手机这一环节暂时就结束了啊,收获还不小呢,哈哈哈哈...







内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: