jquery实现手机号码选号的方法

前端之家收集整理的这篇文章主要介绍了jquery实现手机号码选号的方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

本文实例讲述了jquery实现手机号码选号的方法分享给大家供大家参考。具体如下:

前段时间看到联通的自由组合套餐非常诱人于是决定换号,但选号是个非常累人的活在免费的号码列表中选了好久都没选到心仪的号码,于是写了个脚本去分析这些手机号码,虽然不是非常准确,但至少把那堆垃圾号码过滤掉了。欢迎拍砖。

代码依赖jQuery,有兴趣的自己重构去除依赖。

建议使用Chrome浏览器的调试工具执行。

jquery手机号码分析评分:

scorer = function (/*required RegExp*/reg,/*required Number*/threshold){ return function(/*required char[]*/numberArray){ if(!!numberArray && !!reg && !!threshold){ var matcheList = numberArray.join().match(reg); if(matcheList != null){ return matcheList.length * threshold; } } return 0; }; } //分析后8位号码计算号码分数 function analyseNumbers(/*required String[]*/numberList,/*Optional Object{begin,size}*/range,/*Optional function(char[])[]*/addtionRules){ //无4号码计分 function non4(numberArray){ var threshold = 4; if(!numberArray.inArray("4")){ return threshold; } return 0; } //总数字量加分最高10分 function numberCount(numberArray){ var threshold = 10; var charCount = uniqueArray(numberArray).length; return threshold - ((charCount - 1) * (threshold / (numberArray.length - 1))); } //重复次数加分 function adjoinRepeat(numberArray){ var threshold = 2; var score = 0; for(var i=1;iscore+=threshold*times; }else{ times=0; } } return score; } //顺数加分(3位以上) function straight(numberArray){ var threshold = 2.5; var sideTimes = 2.5//顺数在两端时2.5倍得分 var inverseTimes = 0.6 var score = 0; for(var i=2;i=_arr.length){ return; } if(_arr[i] == _arr[i+1]){ _arr.splice(i+1,1); _unique(_arr,i); }else{ _unique(_arr,i+1); } } var arr=parr.slice().sort(); _unique(arr,0); return arr; } /************* * 计分逻辑 **************/ var nonRepeatList = uniqueArray(numberList); var scorerList = [non4,numberCount,adjoinRepeat,straight,new RegexpMatchscorer(new RegExp("(6|8|9)","g"),0.7)]; if(!!addtionRules){ scorerList.concat(addtionRules); } var scoreTable = []; //分析号码 nonRepeatList.forEach(function(data){ var score = 0; var pn = data.toString(); if(!!range){ pn = pn.substr(range.begin,range.size); } var numberArray = pn.split(""); scorerList.forEach(function(scorer){ score += scorer(numberArray.slice()); }); //发布分数 scoreTable.push({"number":data,"score":score}); }); return scoreTable; }

抓取号码列表,分析:

=sc)x.push(d.number+" : "+d.score);}); return x.sort().join("\n");}) (/*score*/10);

希望本文所述对大家的jquery程序设计有所帮助。

猜你在找的jQuery相关文章