jquery实现手机号码选号的方法
2019/6/29 22:25:43
本文主要是介绍jquery实现手机号码选号的方法,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
本文实例讲述了jquery实现手机号码选号的方法。分享给大家供大家参考。具体如下:
前段时间看到联通的自由组合套餐非常诱人于是决定换号,但选号是个非常累人的活在免费的号码列表中选了好久都没选到心仪的号码,于是写了个脚本去分析这些手机号码,虽然不是非常准确,但至少把那堆垃圾号码过滤掉了。欢迎拍砖。
代码依赖jQuery,有兴趣的自己重构去除依赖。
建议使用Chrome浏览器的调试工具执行。
jquery手机号码分析评分:
/*class*/RegexpMatchScorer = 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;i<numberArray.length;i++){ var times = 0; if(numberArray[i - 1] == numberArray[i]){ times++; score+=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<numberArray.length;i++){ var sTimes = 0; var iTimes = 0; if((Number(numberArray[i])-1==Number(numberArray[i-1]) && Number(numberArray[i])-2==Number(numberArray[i-2]) && ++sTimes) || (Number(numberArray[i])+1==Number(numberArray[i-1]) && Number(numberArray[i])+2==Number(numberArray[i-2]) && ++iTimes) ){ var sc = 0; if(i == 2 || i == numberArray.length - 1){ sc = threshold*sideTimes;//顺数在两端时2.5倍得分 }else{ sc = threshold; } score += sc * (sTimes + iTimes*inverseTimes); }else{ sTimes=0; iTimes=0; } } return score; } //数组去复 function uniqueArray(parr) { function _unique(_arr, i){ if(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; }
抓取号码列表,分析:
?//必须在num.10010.com下执行 var url = "http://num.10010.com/NumApp/GoodsDetail/queryMoreNums?callback=&province=51&cityCode=540&rankMoney=&groupKey=65070778&mid=&q_p=51&net=01&roleValue=&preFeeSel=0&keyValue=&Show4GNum=TRUE&q_p="; var nl = []; for(var i=1;i<=50;i++){ var urli = url+i; $.get(urli,function(data,status){ var _json = eval(data); for(var j=0;j<(_json.moreNumArray.length/7);j++){ var idx = j*7; var num = _json.moreNumArray[idx]; nl.push(num); } }); } //待上面代码抓取号码完毕后分析号码 //查XX分以上的号码 (function(sc){var x=[];analyseNumbers(nl,{begin:-8,size:8}).forEach(function(d,i){if(d.score>=sc)x.push(d.number+" : "+d.score);}); return x.sort().join("\n");}) (/*score*/10);
希望本文所述对大家的jquery程序设计有所帮助。
这篇关于jquery实现手机号码选号的方法的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-03-06jquery对css样式(jquery中的css方法)-icode9专业技术文章分享
- 2023-05-27JQuery的认识和安装
- 2023-01-06JQuery应用技巧:如何定义 HTML 模板并使用 JQuery 进行加载-icode9专业技术文章分享
- 2022-09-29复习-jQuery
- 2022-09-04Python3项目初始化10-->前端基础jquery、ajax,sweetalert--更新用户改造
- 2022-08-30day 27 jquery
- 2022-08-29jQuery筛选器,bootstrap
- 2022-08-20JQuery事件绑定
- 2022-08-20JQuery案例
- 2022-08-07关于jQuery的学习