苹果案例编号查询进度(apple案例进度查询)
苹果手机是目前比较火或者说是一直很火的手机,但是和人一样,人火是非多,东西也是,所以我们买苹果手机的时候都喜欢查询一下是什么时间出的,什么地方出的,但是奈何还要看很多的资料,登录这里那里去查询,有的更恶心的,还要你关注什么微信号才给你说,我也是一个果粉,所以我查看了一下苹果手机序列号的规则,决定做一个小的工具,可以直接查询手机的生产地和具体时间。今天我们就一起做一个!
效果预览:
效果预览
我们简单的将思路说一下:
首先要知道怎么实现这个,要明白的是,苹果手机的序列号是按照什么规则排布的,
规则是:第一位字母:以 c 开头为深圳,以 d 开头为成都,以 f 开头为郑州
序列号的第四位代表生产年份,用 20 个字母表示(26 个字母中除去 a、b、e、i、o 和 u),注意是以每半年一进位。其中,m 代表 2014 年上半年,n 代表 2014 年下半年,p 代表 2015 年上半年,q 代表 2015 年下半年,以此类推。
序列号的第五位是用数字(即 1 到 9,除去 0)和字母(26 个字母中除去 a、b、e、i、o、u、s 和 z)来表示的,共 27 个,代表周数,从 1 开始,数完数字数字母,每半年一循环。比如 n1 和 n9 这两个序列号分别代表 2014 年下半年第一周和第九周生产。
需要注意的是,1 到 9 分别代表第 1 到第 9 周,接下来就是 c,代表第 10 周,以此类推。
这是他的规则,这里需要明确的一点是,他是以半年为一个区间,那么序号的第五位也是半年为一个区间,所以这里首先要判断是上半年还是下半年,然后再去判断具体的日期。
不bb了,看代码,很简单:
css:
*{margin:0;padding:0;list-style-type:none;} a,img{border:0;} body{ background: #000; color: #ddd; font-family: 'helvetica', 'lucida grande', 'arial', sans-serif; } .border,.rain{ width: 320px; } .rain{ padding: 10px 12px 12px 10px; -moz-box-shadow: 10px 10px 10px rgba(0,0,0,1) inset, -9px -9px 8px rgba(0,0,0,1) inset; -webkit-box-shadow: 8px 8px 8px rgba(0,0,0,1) inset, -9px -9px 8px rgba(0,0,0,1) inset; box-shadow: 8px 8px 8px rgba(0,0,0,1) inset, -9px -9px 8px rgba(0,0,0,1) inset; margin: 100px auto; } .border{ padding: 1px; -moz-border-radius: 5px; -webkit-border-radius: 5px; border-radius: 5px; } .border, .rain, .border.start, .rain.start{ background-repeat: repeat-x, repeat-x, repeat-x, repeat-x; background-position: 0 0, 0 0, 0 0, 0 0; background-image: -moz-linear-gradient(left, #09ba5e 0%, #00c7ce 15%, #3472cf 26%, #00c7ce 48%, #0ccf91 91%, #09ba5e 100%); background-image: -webkit-gradient(linear, left top, right top, color-stop(1%,rgba(0,0,0,.3)), color-stop(23%,rgba(0,0,0,.1)), color-stop(40%,rgba(255,231,87,.1)), color-stop(61%,rgba(255,231,87,.2)), color-stop(70%,rgba(255,231,87,.1)), color-stop(80%,rgba(0,0,0,.1)), color-stop(100%,rgba(0,0,0,.25))); background-color: #39f; filter: progid:dximagetransform.microsoft.gradient( startcolorstr='#00ba1b', endcolorstr='#00ba1b',gradienttype=1 ); } .border.end, .rain.end{ -moz-transition-property: background-position; -moz-transition-duration: 30s; -moz-transition-timing-function: linear; -webkit-transition-property: background-position; -webkit-transition-duration: 30s; -webkit-transition-timing-function: linear; -o-transition-property: background-position; -o-transition-duration: 30s; -o-transition-timing-function: linear; transition-property: background-position; transition-duration: 30s; transition-timing-function: linear; background-position: -5400px 0, -4600px 0, -3800px 0, -3000px 0; } @-webkit-keyframes colors { 0% {background-color: #39f;} 15% {background-color: #f246c9;} 30% {background-color: #4453f2;} 45% {background-color: #44f262;} 60% {background-color: #f257d4;} 75% {background-color: #edf255;} 90% {background-color: #f20006;} 100% {background-color: #39f;} } .border,.rain{ -webkit-animation-direction: normal; -webkit-animation-duration: 20s; -webkit-animation-iteration-count: infinite; -webkit-animation-name: colors; -webkit-animation-timing-function: ease; } .border.unfocus{ background: #333 !important; -moz-box-shadow: 0px 0px 15px rgba(255,255,255,.2); -webkit-box-shadow: 0px 0px 15px rgba(255,255,255,.2); box-shadow: 0px 0px 15px rgba(255,255,255,.2); -webkit-animation-name: none; } .rain.unfocus{ background: #000 !important; -webkit-animation-name: none; } form{ background: #212121; -moz-border-radius: 5px; -webkit-border-radius: 5px; border-radius: 5px; height:220px; width: 100%; background: -moz-radial-gradient(50% 46% 90deg,circle closest-corner, #242424, #090909); background: -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 150, from(#242424), to(#090909)); } form label{ display: block; padding: 10px 10px 5px 15px; font-size: 11px; color: #777; } form input{ display: block; margin: 5px 10px 10px 15px; width: 85%; background: #111; -moz-box-shadow: 0px 0px 4px #000 inset; -webkit-box-shadow: 0px 0px 4px #000 inset; box-shadow: 0px 0px 4px #000 inset; outline: 1px solid #333; border: 1px solid #000; padding: 5px; color: #444; font-size: 16px; } form input:focus{ outline: 1px solid #555; color: #fff; } input[type="button"]{ color: #999; padding: 5px 10px; border: 1px solid #000; font-weight: lighter; -moz-border-radius: 15px; -webkit-border-radius: 15px; border-radius: 15px; background: #45484d; background: -moz-linear-gradient(top, #222 0%, #111 100%); background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#222), color-stop(100%,#111)); filter: progid:dximagetransform.microsoft.gradient( startcolorstr='#22222', endcolorstr='#11111',gradienttype=0 ); -moz-box-shadow: 0px 1px 1px #000, 0px 1px 0px rgba(255,255,255,.3) inset; -webkit-box-shadow: 0px 1px 1px #000, 0px 1px 0px rgba(255,255,255,.3) inset; box-shadow: 0px 1px 1px #000,0px 1px 0px rgba(255,255,255,.3) inset; text-shadow: 0 1px 1px #000; outline: none; width:80px; margin-top:20px; float: left; }
css可以不看,美观一点而已
引用:
<link rel="stylesheet" type="text/css" href="css/layui/css/layui.css"/> <script src="js/jquery.min.js" type="text/javascript" charset="utf-8"></script> <script src="css/layui/lay/dest/layui.all.js" type="text/javascript" charset="utf-8"></script>
js:
$(function(){ var $form_inputs = $('form input'); var $rainbow_and_border = $('.rain, .border'); $form_inputs.bind('focus', function(){ $rainbow_and_border.addclass('end').removeclass('unfocus start'); }); $form_inputs.bind('blur', function(){ $rainbow_and_border.addclass('unfocus start').removeclass('end'); }); $form_inputs.first().delay(800).queue(function(){ $(this).focus(); }); }); var address;//生产地 var years;//生产年份 var dates;//生产日期 function checkappleid(){ /* 截取到第一位字符,用来判断的是生产地址 */ var id = $("#checkapple").val(); var apple_adress = id.substr(0,1); //截取的是第一位的字符串,然后截取的长度是一位 /* 截取到第四位的字符,用来判断的是生产年份 */ var year = id.substr(3,1); /* 截取到第五位的字符,用来判断生产日期 */ var dateflag = id.substr(4,1);//截取到第五位 /* 先判断是不是正确的是序列号 */ if(id.length != 12){ layer.msg("序列号有误!请核对对后重新查询"); } else{ if(apple_adress == 'c'){ address = '深圳'; }else if(apple_adress == 'd'){ address = '成都' }else if(apple_adress == 'f'){ address = '郑州' }else{ layer.msg("序列号有误!请核对对后重新查询"); return false; } console.log("生产地是:"+address); console.log("第四位是:"+year); console.log("第五位是:"+dateflag); if(year == 'm'){ years = '2014上半年'; check_before(dateflag); }else if(year == 'n'){ years = '2014下半年'; check_after(dateflag); }else if(year == 'p'){ years = '2015上半年'; check_before(dateflag); }else if(year == 'q'){ years = '2015下半年'; check_after(dateflag); }else if(year == 'r'){ years = '2016上半年'; check_before(dateflag); }else if(year == 's'){ years = '2016下半年'; check_after(dateflag); }else if(year == 't'){ years = '2017上半年'; check_before(dateflag); }else if(year == 'v'){ years = '2017下半年'; check_after(dateflag); }else if(year == 'w'){ years = '2018上半年'; check_before(dateflag); }else if(year == 'x'){ years = '2018下半年'; check_after(dateflag); }else if(year == 'y'){ years = '2019上半年'; check_before(dateflag); }else if(year == 'z'){ years = '2019下半年'; check_after(dateflag); }else{ layer.msg("序列号有误!请核对对后重新查询"); return false; } console.log("年份是:"+years); console.log("日期是:"+dates); layer.open({ type: 1, title:'查询结果', skin: 'layui-layer-rim', //加上边框 area: ['600px', '400px'], //宽高 btn:['关闭'], content: '您的序列号是:'+id+'<br/>'+ '该是手机生产地是:'+address+'<br/>'+ '该是手机生产年份是:'+years+'<br/>'+ '该是手机生产日期是:'+dates+'<br/>'+ '提示:如果您查询的激活日期早于生产日期,说明您的手机是官换机!', }); } } /* 判断的是每一年的下半年的日期 */ function check_before(dateflag){ if(dateflag == '1'){ dates = '1月1日-1月7日'; }else if(dateflag == '2'){ dates = '1月8日-1月14日'; }else if(dateflag == '3'){ dates = '1月15日-1月21日'; }else if(dateflag == '4'){ dates = '1月22日-1月28日'; }else if(dateflag == '5'){ dates = '1月29日-2月4日'; }else if(dateflag == '6'){ dates = '2月5日-2月11日'; }else if(dateflag == '7'){ dates = '2月12日-2月18日'; }else if(dateflag == '8'){ dates = '2月19日-2月25日'; }else if(dateflag == '9'){ dates = '2月26日-3月1日'; }else if(dateflag == 'c'){ dates = '3月2日-3月8日'; }else if(dateflag == 'd'){ dates = '3月9日-3月15日'; }else if(dateflag == 'f'){ dates = '3月16日-3月22日'; }else if(dateflag == 'g'){ dates = '3月23日-3月29日'; }else if(dateflag == 'h'){ dates = '4月30日-4月6日'; }else if(dateflag == 'j'){ dates = '4月7日-4月13日'; }else if(dateflag == 'k'){ dates = '4月14日-4月20日'; }else if(dateflag == 'l'){ dates = '4月21日-4月27日'; }else if(dateflag == 'm'){ dates = '4月28日-5月3日'; }else if(dateflag == 'n'){ dates = '5月4日-5月10日'; }else if(dateflag == 'p'){ dates = '5月11日-5月17日'; }else if(dateflag == 'q'){ dates = '5月18日-5月24日'; }else if(dateflag == 'r'){ dates = '5月25日-6月1日'; }else if(dateflag == 't'){ dates = '6月2日-6月8日'; }else if(dateflag == 'v'){ dates = '6月9日-6月15日'; }else if(dateflag == 'w'){ dates = '6月16日-6月22日'; }else if(dateflag == 'x'){ dates = '6月23日-6月29日'; }else if(dateflag == 'y'){ dates = '6月30日'; }else{ layer.msg("序列号有误!请核对对后重新查询"); return false; } } /* 判断的是下半年具体日期 */ function check_after(dateflag){ if(dateflag == '1'){ dates = '7月1日-7月7日'; }else if(dateflag == '2'){ dates = '7月8日-7月14日'; }else if(dateflag == '3'){ dates = '7月15日-7月21日'; }else if(dateflag == '4'){ dates = '7月22日-7月28日'; }else if(dateflag == '5'){ dates = '7月29日-8月4日'; }else if(dateflag == '6'){ dates = '8月5日-8月11日'; }else if(dateflag == '7'){ dates = '8月12日-8月18日'; }else if(dateflag == '8'){ dates = '8月19日-8月25日'; }else if(dateflag == '9'){ dates = '8月26日-9月1日'; }else if(dateflag == 'c'){ dates = '9月2日-9月8日'; }else if(dateflag == 'd'){ dates = '9月9日-9月15日'; }else if(dateflag == 'f'){ dates = '9月16日-9月22日'; }else if(dateflag == 'g'){ dates = '9月23日-9月29日'; }else if(dateflag == 'h'){ dates = '9月30日-10月6日'; }else if(dateflag == 'j'){ dates = '10月7日-10月13日'; }else if(dateflag == 'k'){ dates = '10月14日-10月20日'; }else if(dateflag == 'l'){ dates = '10月21日-10月27日'; }else if(dateflag == 'm'){ dates = '10月28日-11月3日'; }else if(dateflag == 'n'){ dates = '11月4日-11月10日'; }else if(dateflag == 'p'){ dates = '11月11日-11月17日'; }else if(dateflag == 'q'){ dates = '11月18日-11月24日'; }else if(dateflag == 'r'){ dates = '11月25日-12月1日'; }else if(dateflag == 't'){ dates = '12月2日-12月8日'; }else if(dateflag == 'v'){ dates = '12月9日-12月15日'; }else if(dateflag == 'w'){ dates = '12月16日-12月22日'; }else if(dateflag == 'x'){ dates = '12月23日-12月29日'; }else if(dateflag == 'y'){ dates = '12月30日-12月31日'; }else{ layer.msg("序列号有误!请核对对后重新查询"); return false; } } /*苹果的全系列产品 */ function apple_info(){ layer.open({ type: 1, title:'苹果全系类产品', skin: 'layui-layer-rim', //加上边框 area: ['600px', '400px'], //宽高 btn:['关闭'], content:'型号:iphone第一代,发布日期:2007年1月9日<hr><br/>'+ '型号:3g,发布日期:2008年06月10日<hr><br/>'+ '型号:3gs,发布日期:2009年6月9日<hr><br/>'+ '型号:4,发布日期:2010年6月8日<hr><br/>'+ '型号:4s,发布日期:2011年10月04日<hr><br/>'+ '型号:5,发布日期:2012年9月13日<hr><br/>'+ '型号:5c,发布日期:2013年9月10日<hr><br/>'+ '型号:5s,发布日期:2013年9月10日<hr><br/>'+ '型号:6,发布日期:2014年9月10日<hr><br/>'+ '型号:6p,发布日期:2014年9月10日<hr><br/>'+ '型号:6s,发布日期:2015年9月10日<hr><br/>'+ '型号:6sp,发布日期:2015年9月10日<hr><br/>'+ '型号:7,发布日期:2016年9月8日<hr><br/>'+ '型号:7p,发布日期:2016年9月8日<hr><br/>'+ '型号:8,发布日期:2017年9月13日<hr><br/>'+ '型号:8p,发布日期:2017年9月13日<hr><br/>'+ '型号:x,发布日期:2017年9月13日<hr><br/>'+ '官方网址:<a href="https://www.apple.com/cn//?afid=p238%7c1dxlb2qwz-dc_mtid_18707vxu38484_pcrid_16834665582_&cid=aos-cn-kwba-brand" target="_blank">点击进入<a/>', }); } function reload(){ location.reload(); }
当然这里您使用switch case写也是可以的,毕竟if else很麻烦,写法是这样的:
/* 判断地址 */ switch (apple_adress){ case 'c': address = '深圳'; break; case 'd': address = '成都'; break; case 'f': address = '郑州'; break; default: layer.msg("序列号有误!请核对对后重新查询"); return false; }
h5:
<div class="rain"> <div class="border start"> <form> <label for="text">苹果手机序列号查询</label> <input name="text" type="text" placeholder="序列号" id="checkapple"/> <input type="button" value="查询" onclick="checkappleid()"/> <input type="button" value="取消" onclick="reload()"/> <input type="button" value="苹果" onclick="apple_info()"/> </form> </div> </div>
思路是:
拿到用户输入的序列号-截取第一位,第四位,第五位的值-根据规则判断值-给对应的参数赋值
喜欢的可以关注我,一起学习,虽然写的没有什么技术含量,但是还是很实用的,毕竟思路清晰是锻炼出来的,一点点积累吧!