Das Beispiel in diesem Artikel beschreibt, wie jquery die Auswahl von Mobiltelefonnummern implementiert. Teilen Sie es als Referenz mit allen. Die Details lauten wie folgt:
Vor einiger Zeit habe ich gesehen, dass das kostenlose Kombipaket von China Unicom sehr attraktiv war, also habe ich beschlossen, meine Nummer zu ändern. Allerdings war die Auswahl einer Nummer im kostenlosen Paket nicht möglich Deshalb habe ich ein Skript geschrieben, das zwar nicht sehr genau ist, aber zumindest die Junk-Nummern herausfiltert. Willkommen bei der Herstellung von Ziegeln.
Der Code hängt von jQuery ab. Wenn Sie interessiert sind, können Sie ihn selbst umgestalten, um die Abhängigkeit zu entfernen.
Es wird empfohlen, zur Ausführung das Debugging-Tool des Chrome-Browsers zu verwenden.
Jquery-Analyseergebnis für Mobiltelefonnummern:
/*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; }
Erfassen Sie die Nummernliste und analysieren Sie:
//必须在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);
Ich hoffe, dass dieser Artikel für das JQuery-Programmierungsdesign aller hilfreich sein wird.