欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

jquery實現(xiàn)手機號碼選號的方法

 更新時間:2015年07月31日 11:59:00   作者:starstroll  
這篇文章主要介紹了jquery實現(xiàn)手機號碼選號的方法,涉及jquery針對手機號碼的分析與篩選技巧,具有一定參考借鑒價值,需要的朋友可以參考下

本文實例講述了jquery實現(xiàn)手機號碼選號的方法。分享給大家供大家參考。具體如下:

前段時間看到聯(lián)通的自由組合套餐非常誘人于是決定換號,但選號是個非常累人的活在免費的號碼列表中選了好久都沒選到心儀的號碼,于是寫了個腳本去分析這些手機號碼,雖然不是非常準確,但至少把那堆垃圾號碼過濾掉了。歡迎拍磚。

代碼依賴jQuery,有興趣的自己重構去除依賴。

建議使用Chrome瀏覽器的調試工具執(zhí)行。

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位號碼計算號碼分數(shù)
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;
 }
 //總數(shù)字量加分最高10分
 function numberCount(numberArray){
  var threshold = 10;
  var charCount = uniqueArray(numberArray).length;
  return threshold - ((charCount - 1) * (threshold / (numberArray.length - 1)));
 }
 //重復次數(shù)加分
 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;
 }
 //順數(shù)加分(3位以上)
 function straight(numberArray){
  var threshold = 2.5;
  var sideTimes = 2.5//順數(shù)在兩端時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;//順數(shù)在兩端時2.5倍得分
    }else{
     sc = threshold;
    }
    score += sc * (sTimes + iTimes*inverseTimes);
   }else{
    sTimes=0;
    iTimes=0;
   }
  }
  return score;
 }
 //數(shù)組去復
 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());
  });
  //發(fā)布分數(shù)
  scoreTable.push({"number":data, "score":score});
 });
 return scoreTable;
}

抓取號碼列表,分析:

//必須在num.10010.com下執(zhí)行
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 tab標簽頁的制作

    jquery tab標簽頁的制作

    制作標簽頁(通常說成滑動門)的實現(xiàn)思路是當鼠標在標簽上時下面div會顯示和標簽相對應的內容,隨著標簽的改變,下面的div也會對應改變內容
    2010-05-05
  • jQuery實現(xiàn)表格隔行及滑動,點擊時變色的方法【測試可用】

    jQuery實現(xiàn)表格隔行及滑動,點擊時變色的方法【測試可用】

    這篇文章主要介紹了jQuery實現(xiàn)表格隔行及滑動,點擊時變色的方法,可實現(xiàn)表格隔行變色以及鼠標滑過與點擊時變色的功能,涉及jQuery響應鼠標事件及頁面元素樣式動態(tài)改變的相關技巧,需要的朋友可以參考下
    2016-08-08
  • jQuery簡單實現(xiàn)iframe的高度根據(jù)頁面內容自適應的方法

    jQuery簡單實現(xiàn)iframe的高度根據(jù)頁面內容自適應的方法

    這篇文章主要介紹了jQuery簡單實現(xiàn)iframe的高度根據(jù)頁面內容自適應的方法,給出了2種簡單實現(xiàn)方法,涉及jQuery針對頁面高度的動態(tài)獲取與設置相關技巧,需要的朋友可以參考下
    2016-08-08
  • 基于jQuery實現(xiàn)表單提交驗證

    基于jQuery實現(xiàn)表單提交驗證

    本文給大家分享的是一段基于jQuery的實現(xiàn)簡單的表單提交驗證的代碼,非常簡單實用,推薦給有相同需求的小伙伴們參考下。
    2014-11-11
  • 基于jQuery實現(xiàn)發(fā)送短信驗證碼后的倒計時功能(無視頁面關閉)

    基于jQuery實現(xiàn)發(fā)送短信驗證碼后的倒計時功能(無視頁面關閉)

    最近做了一個項目,其中有需求要求實現(xiàn)發(fā)送短信驗證碼后倒計時功能,其中有個難點:要求關閉頁面也進行倒計時。好吧,下面小編把jquery 發(fā)送驗證碼倒計時的實現(xiàn)代碼分享給大家,大家可以參考下
    2016-09-09
  • jquery用data方法獲取某個元素上的事件

    jquery用data方法獲取某個元素上的事件

    如何獲取某個元素上的事件,jquery的給元素綁定的事件可以用data方法取出來,下面有個示例,大家可以參考下
    2014-06-06
  • jquery 為a標簽綁定click事件示例代碼

    jquery 為a標簽綁定click事件示例代碼

    jquery 為a標簽綁定click事件,當被點擊時執(zhí)行一些動作,示例代碼如下,需要的朋友可以參考參考
    2014-06-06
  • jquery自定義顯示消息數(shù)量

    jquery自定義顯示消息數(shù)量

    這篇文章主要為大家詳細介紹了基于jquery自定義顯示消息數(shù)量,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-12-12
  • JQuery屬性操作與循環(huán)用法示例

    JQuery屬性操作與循環(huán)用法示例

    這篇文章主要介紹了JQuery屬性操作與循環(huán)用法,結合實例形式分析了jQuery屬性讀取、設置,以及針對頁面元素循環(huán)遍歷相關操作技巧,需要的朋友可以參考下
    2019-05-05
  • jQuery+HTML5加入購物車代碼分享

    jQuery+HTML5加入購物車代碼分享

    這篇文章主要為大家詳細介紹了jQuery+HTML5加入購物車的實現(xiàn)代碼,功能很齊全,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2015-08-08

最新評論