js顏色生成器

公共函數(shù)
  • DJB算法
function genHash (str){
    var hash = 5381;
    str = str || '';
    for(var i=0, len=str.length; i<len; ++i){
        hash += (hash << 5) + str.charAt(i).charCodeAt();
    }
    return hash & 0x7fffffff;
}
  • 補(bǔ)齊或截取九位長度
function cut(num){
    return (genHash(num)+ "000000000").slice(0, 9);
}
兩種生成顏色方法
  1. for循環(huán)
//創(chuàng)建RGB顏色
function createRGBColor(num){
    var uin = cut(num);var rgb = [];
    for(var i = 0 ; i < uin.length ; i+=3 ){
        var rgbnum = uin.substr(i,3) % 255;
        if(rgbnum < 64) rgbnum += 64;
        rgb.push(rgbnum);
    }
    return 'rgb(' + rgb.join(',') + ')';
}

timeline錄制耗時

Image.png
  1. 正則替換
function createRGBColor(num){
    var colorString = "#" + (cut(num).replace(/(\d{3})/g, function($0) {
        var c = $0 % 255;
        if(c < 64) c += 64;
        return c.toString(16);
    }));
    return colorString;
}

timeline錄制耗時

Image.png
大量計算測試(百萬次)
//DJB算法
function genHash (str){
    var hash = 5381;str = str || '';
    for(var i=0, len=str.length; i<len; ++i){
        hash += (hash << 5) + str.charAt(i).charCodeAt();
    }
    return hash & 0x7fffffff;
}

//補(bǔ)齊或截取九位長度
function cut(num){
    return (genHash(num)+ "000000000").slice(0, 9);
}
// console.log(cut('35467684654'));

//創(chuàng)建rgb(96,145,215)顏色
function createRGBColor(num){
    var uin = cut(num);
    var rgb = [];
    for(var i = 0 ; i < uin.length ; i+=3 ){
        var rgbnum = uin.substr(i,3) % 255;
        if(rgbnum < 64) rgbnum += 64;
        rgb.push(rgbnum);
    }
    var ret = 'rgb(' + rgb.join(',') + ')'return ret;
}

//創(chuàng)建#12F5V2顏色
function createRGBColorReg(num){
    var colorString = "#" + (cut(num).replace(/(\d{3})/g, function($0) {
        var c = $0 % 255;
        if(c < 64) c += 64;
        return c.toString(16);
    }));
    return colorString;
}

var TIMES = 1000;
var data = [,,,,,,];

//省略递递,上千數(shù)據(jù)的數(shù)組
var startCreateRGBColorReg = function() {
    var ret = [];
    console.time("createRGBColorReg");
    for(var i = TIMES;i>0; i--) {
        data.forEach(function(appid){
            createRGBColorReg(appid);
        });
    }
    console.timeEnd("createRGBColorReg");
    return 1;
};

var startCreateRGBColor = function() {
    var ret = [];
    console.time("createRGBColor");
    for(var i = TIMES;i>0; i--) {
        data.forEach(function(appid){
            createRGBColor(appid);
        });
    }
    console.timeEnd("createRGBColor");
    return 1;
};

var init = function() {
    startCreateRGBColorReg();
    startCreateRGBColor();
};
init();
測試數(shù)據(jù)
Image.png
測試證明:截斷操作使用循環(huán)的效率快于正則
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末盐须,一起剝皮案震驚了整個濱河市瞻鹏,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌溉苛,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,946評論 6 518
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異辰如,居然都是意外死亡赞咙,警方通過查閱死者的電腦和手機(jī)责循,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,336評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來攀操,“玉大人院仿,你說我怎么就攤上這事∷俸停” “怎么了歹垫?”我有些...
    開封第一講書人閱讀 169,716評論 0 364
  • 文/不壞的土叔 我叫張陵,是天一觀的道長颠放。 經(jīng)常有香客問我排惨,道長,這世上最難降的妖魔是什么慈迈? 我笑而不...
    開封第一講書人閱讀 60,222評論 1 300
  • 正文 為了忘掉前任若贮,我火速辦了婚禮省有,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘谴麦。我一直安慰自己蠢沿,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,223評論 6 398
  • 文/花漫 我一把揭開白布匾效。 她就那樣靜靜地躺著舷蟀,像睡著了一般。 火紅的嫁衣襯著肌膚如雪面哼。 梳的紋絲不亂的頭發(fā)上野宜,一...
    開封第一講書人閱讀 52,807評論 1 314
  • 那天,我揣著相機(jī)與錄音魔策,去河邊找鬼匈子。 笑死,一個胖子當(dāng)著我的面吹牛闯袒,可吹牛的內(nèi)容都是我干的虎敦。 我是一名探鬼主播,決...
    沈念sama閱讀 41,235評論 3 424
  • 文/蒼蘭香墨 我猛地睜開眼政敢,長吁一口氣:“原來是場噩夢啊……” “哼其徙!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起喷户,我...
    開封第一講書人閱讀 40,189評論 0 277
  • 序言:老撾萬榮一對情侶失蹤唾那,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后褪尝,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體闹获,經(jīng)...
    沈念sama閱讀 46,712評論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,775評論 3 343
  • 正文 我和宋清朗相戀三年恼五,在試婚紗的時候發(fā)現(xiàn)自己被綠了昌罩。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,926評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡灾馒,死狀恐怖茎用,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情睬罗,我是刑警寧澤轨功,帶...
    沈念sama閱讀 36,580評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站容达,受9級特大地震影響古涧,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜花盐,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,259評論 3 336
  • 文/蒙蒙 一羡滑、第九天 我趴在偏房一處隱蔽的房頂上張望菇爪。 院中可真熱鬧,春花似錦柒昏、人聲如沸凳宙。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,750評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽氏涩。三九已至,卻和暖如春有梆,著一層夾襖步出監(jiān)牢的瞬間是尖,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,867評論 1 274
  • 我被黑心中介騙來泰國打工泥耀, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留饺汹,地道東北人。 一個月前我還...
    沈念sama閱讀 49,368評論 3 379
  • 正文 我出身青樓爆袍,卻偏偏與公主長得像首繁,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子陨囊,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,930評論 2 361

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,338評論 25 707
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)夹攒,斷路器蜘醋,智...
    卡卡羅2017閱讀 134,719評論 18 139
  • 提筆竟然開不了第一句,到底該寫些什么了咏尝,我絞盡腦汁压语,想了又想,還是不知道怎么開頭编检,明明早晨就已經(jīng)想好了的話題胎食,現(xiàn)在...
    coffee漫閱讀 260評論 2 2
  • 光陰荏苒厕怜,轉(zhuǎn)眼之間來到五月。又是一年勞動節(jié)蕾总,也是出行旅游日粥航。而我,這些都跟我不相干生百。 春天就要過去了递雀,夏日還遠(yuǎn)么?...
    大野的竹閱讀 392評論 0 0