掃二維碼與項(xiàng)目經(jīng)理溝通
我們?cè)谖⑿派?4小時(shí)期待你的聲音
解答本文疑問(wèn)/技術(shù)咨詢/運(yùn)營(yíng)咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流
我為大家準(zhǔn)備了一個(gè)密碼生成工具,有0-9和a-k的英文字母組成,數(shù)字是亂序排列。字母隨機(jī)一個(gè)替換掉一個(gè)數(shù)字,生成一個(gè)長(zhǎng)度為10的密碼。

- "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
怎樣亂序排列數(shù)組,本人數(shù)學(xué)比較爛。搜索了一下給array的sort傳入一個(gè)這樣的函數(shù)。
sort真是強(qiáng)大啊。
- function unorderedArray(array){
- if(({}).toString.call(array).indexOf('Array')===-1) return;
- var arr=[],value=array.toString();
- arr=array.sort(function(){return Math.random()>0.5?-1:1;});
- (arr.toString()===value) && arguments.callee(array);
- return arr;
- }
在用這個(gè)方法的時(shí)候要避免生成的數(shù)組和傳入的數(shù)組一樣,頗廢了點(diǎn)功夫,因?yàn)閿?shù)組是復(fù)雜類型,有修改所有的都會(huì)有變化。所以用一個(gè)變量去緩存了傳入的數(shù)組的值value=array.toString(),然后我生成的數(shù)組的值比較一下如果相對(duì)就遞歸一次。保證生成的數(shù)組不是順序的。
用下面的代碼生成一個(gè)0-9的隨機(jī)數(shù)序號(hào)
- Math.random().toFixed(1) * 10-1;
用這個(gè)序號(hào)去獲得a-k的一個(gè)字母,用這個(gè)字母去替換數(shù)組中序號(hào)相應(yīng)位置的數(shù)字。
在用數(shù)組的join方法把獲得的數(shù)組字符串化
- password.join('');
獲得一個(gè)密鑰。
原文:http://www.cnblogs.com/enix/archive/2011/12/22/2297913.html
【編輯推薦】

我們?cè)谖⑿派?4小時(shí)期待你的聲音
解答本文疑問(wèn)/技術(shù)咨詢/運(yùn)營(yíng)咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流