JScript Array对象的几个原型方法

原创 2006年06月08日 14:58:00
Array.prototype.inArray = function (value) {
for (var i = 0; i < this.length; i++) {
if (this[i] === value) {
return true;
}
}
return false;
};

Array.prototype.max = function(){
for (var i = 1, max = this[0]; i < this.length; i++){
if (max < this[i]) {
max = this[i];
}
return max;
};

Array.prototype.min = function(){
for (var i = 1, min = this[0]; i < this.length; i++){
if (min > this[i]) {
min = this[i];
}
return min;
};

Array.prototype.indexOf = function(p_var)
{
for (var i=0; i<this.length; i++)
{
if (this[i] == p_var)
{
return(i);
}
}
return(-1);
}

Array.prototype.exists = function(p_var) {return(this.indexOf(p_var) != -1);}

Array.prototype.queue = function(p_var) {this.push(p_var)}

Array.prototype.dequeue = function() {return(this.shift());}

Array.prototype.removeAt = function(p_iIndex) {return this.splice(p_iIndex, 1);}

Array.prototype.remove = function(o)
{
var i = this.indexOf(o);
if (i>-1)
{
this.splice(i,1);
}
return (i>-1);
}

Array.prototype.clear = function()
{
var iLength = this.length;
for (var i=0; i < iLength; i++)
{
this.shift();
}
}

Array.prototype.addArray = function(p_a)
{
if (p_a)
{
for (var i=0; i < p_a.length; i++)
{
this.push(p_a[i]);
}
}
}

Array.prototype.Unique = function()
{
var a = {}; for(var i=0; i<this.length; i++)
{
if(typeof a[this[i]] == "undefined")
a[this[i]] = 1;
}
this.length = 0;
for(var i in a)
this[this.length] = i;
return this;
};

Array.prototype.indexOf = function(obj, fromIndex)
{
if (fromIndex == null)
{
fromIndex = 0;
}
else if (fromIndex < 0)
{
fromIndex = Math.max(0, this.length + fromIndex);
}

for (var i = fromIndex; i < this.length; i++)
{
if (this[i] === obj)
{
return i;
}
}

return-1;
};

Array.prototype.lastIndexOf = function(obj, fromIndex)
{
if (fromIndex == null)
{
fromIndex = this.length - 1;
}
else if (fromIndex < 0)
{
fromIndex=Math.max(0, this.length+fromIndex);
}

for (var i = fromIndex; i >= 0; i--)
{
if (this[i] === obj)
{
return i;
}
}

return -1;
};

Array.prototype.insertAt = function(o, i)
{
this.splice(i, 0, o);
};

Array.prototype.insertBefore = function(o, o2)
{
var i = this.indexOf(o2);

if (i == -1)
{
this.push(o);
}
else
{
this.splice(i, 0, o);
}
};

Array.prototype.remove = function(o)
{
var i = this.indexOf(o);

if (i != -1)
{
this.splice(i, 1);
}
};

Array.prototype.mm=function()
{
var a={}, m=0, n="";
for(var i=0; i<this.length; i++)
a[this[i]]?++a[this[i]]:a[this[i]]=1;
for(i in a){m=Math.max(m, a[i]); if(m==a[i]) n=i;}
return {"variable": n, "times": m};
}

Js的Array对象的几个原型方法

代码 Array.prototype.inArray = function(value) { for (var i = 0; i < this.length; i++) { ...
  • liuzx32
  • liuzx32
  • 2012年07月18日 09:44
  • 272

获取JScript对象的expando属性的方法

参考: 只遍历出JScript对象的expando属性 处了object的hasOwnProperty方法可以获得JScript对象的expando属性外,还可以通过for in 遍历来实现。代...

javaScript随机生成一个5位以内的数,及数组对象Array原型forEach解析

javaScript随机生成一个5位以内的数,及数组对象Array原型forEach解析

JavaScript Array 原型方法 大盘点

数组是一个超常用的数据结构,JavaScript的数组方法都有什么怎样的特性呢?是时候一探究竟了。JavaScript中数组是一个对象,默认的赋值是传了一个引用。针对结果是引用还是拷贝,对原数组的变更...
  • zccz14
  • zccz14
  • 2016年06月04日 13:12
  • 2483

分针网—每日分享:JavaScript Array 原型方法 大盘点

免费IT学习资料 加群:272292492 数组是一个超常用的数据结构,JavaScript的数组方法都有什么怎样的特性呢? ...

在Array原型链上扩展remove,contain等方法所遇到的坑

 相信jser兄弟们肯定会碰到这样一个问题, 在做数组类的操作的时候,会要求删除数组中的一个元素;亦或是判断某值是否存在于这个数组; OK,拿删除数组元素举例,扩展方法为: Array...

JScript中的prototype(原型)属性研究(1)

我们知道JScript中对象的prototype属性,是用来返回对象类型原型的引用的。我们使用prototype属性提供对象的类的一组基本功能。并且对象的新实例会"继承"赋予该对象原型的操作。但是这个...

JScript中的prototype(原型)属性研究(2)

 上次的文章中我罗列了一下prototype属性在JScript中的各种用法,但是prototype这个东西却不是JScript创造出来的,JScript实际上是使用了我们设计模式中prototype...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JScript Array对象的几个原型方法
举报原因:
原因补充:

(最多只允许输入30个字)