最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
JavaScript数组对象实现增加一个返回随机元素的方法
时间:2015-07-27 编辑:简简单单 来源:一聚教程网
为Array对象新增random方法:
(function () {
function Random_SN(iArray) {
return Math.floor(Math.random() * iArray.length);
}
function Probability_Random(iArray) {
var Random_Int;
if (iArray.Random_SN === undefined)
iArray.Random_SN = -1;
do Random_Int = Random_SN(iArray);
while ( Random_Int == iArray.Random_SN )
iArray.Random_SN = Random_Int;
return iArray[Random_Int];
}
function Sequence_Random(iArray) {
return iArray.splice(Random_SN(iArray), 1)[0];
}
Array.prototype.random = function (Mode, Pop) {
if (! Mode)
return Probability_Random(this);
if (! Pop) {
if (! (this.Random_Queue && this.Random_Queue.length))
this.Random_Queue = [].concat(this);
return Sequence_Random(this.Random_Queue);
}
return Sequence_Random(this);
};
})();
使用示例:
// 【概率随机】
//
// 元素的返回 完全随机,出现几率不定,有限次调用不保证能返回所有元素
var iElement = iArray.random();
// 【顺序随机】
//
// 元素的返回 有周期性,在每个周期内,元素都出现一次,但顺序不定
var iElement = iArray.random(true);
// 【随机冒泡】
//
// 每次调用都从原数组中随机取出一个元素返回(原数组 就地改变)
var iElement = iArray.random(true, true);
相关文章
- HTML简单购物数量小程序代码展示 10-31
- html canvas实现弹幕功能 10-31
- HTML中空格表示的意义 10-31
- html area标签解读 10-31
- html使用表单标签实现注册页面代码展示 10-31
- 使用HTML截图并保存为本地图片的代码展示 10-31