js實(shí)現(xiàn)1,2,3,5數(shù)字按照概率生成
更新時間:2017年09月12日 18:43:03 投稿:mdxy-dxy
這篇文章主要介紹了js實(shí)現(xiàn)1,2,3,5數(shù)字按照概率生成,需要的朋友可以參考下
js按照配置的概率生成,概率規(guī)則如下:
1------------50%
2------------30%
3------------15%
5------------5%
簡單的代碼
function myRandom() { var rand = Math.random(); if (rand < .5) return 1; if (rand < .8) return 2; if (rand < .95) return 3; return 5; }
復(fù)雜點(diǎn)的
function prizeRand(oArr) { var sum = 0; // 總和 var rand = 0; // 每次循環(huán)產(chǎn)生的隨機(jī)數(shù) var result = 0; // 返回的對象的key console.log(oArr); // 計(jì)算總和 for (var i in oArr) { sum += oArr[i][0]; } // 思路就是如果設(shè)置的數(shù)落在隨機(jī)數(shù)內(nèi),則返回,否則減去本次的數(shù) for (var i in oArr) { rand = Math.floor(Math.random()*sum + 1); if (oArr[i][0] >= rand) { result = oArr[i][0]; break; } else { sum -= oArr[i][0]; } } return result; } var oArr = {'5':[5, 'Mac'], '3':[15, 'iPhone'], '2':[30, 'iPad'], '1':[50, 'iWatch']}; console.log(prizeRand(oArr));
大家可以根據(jù)需要選擇,建議查看腳本之家的上一篇文章。
您可能感興趣的文章:
相關(guān)文章
js實(shí)現(xiàn)對ajax請求面向?qū)ο蟮姆庋b
這篇文章主要介紹了js實(shí)現(xiàn)對ajax請求面向?qū)ο蟮姆庋b的相關(guān)資料,需要的朋友可以參考下2016-01-01基于js Canvas實(shí)現(xiàn)二次貝塞爾曲線
這篇文章主要為大家詳細(xì)介紹了基于js Canvas實(shí)現(xiàn)二次貝塞爾曲線,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-12-12jQuery實(shí)現(xiàn)手風(fēng)琴特效
這篇文章主要為大家詳細(xì)介紹了前端js實(shí)現(xiàn)手風(fēng)琴效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-01-01EXTJS7實(shí)現(xiàn)點(diǎn)擊拖拉選擇文本
這篇文章主要為大家詳細(xì)介紹了EXTJS7實(shí)現(xiàn)點(diǎn)擊拖拉選擇文本,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-12-12js構(gòu)造函數(shù)創(chuàng)建對象是否加new問題
本篇文章主要給大家詳細(xì)分析了js構(gòu)造函數(shù)創(chuàng)建對象加new與不加new的問題,有這方面興趣的參考學(xué)習(xí)下。2018-01-01js點(diǎn)擊按鈕實(shí)現(xiàn)水波紋效果代碼(CSS3和Canves)
這篇文章主要為大家詳細(xì)介紹了點(diǎn)擊按鈕實(shí)現(xiàn)水波紋效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-09-09