object类是所以javascript类的基类,提供了一种创建自定义对象的简单方式,不需要程序员再定义构造函数。
主要属性:
1.constructor——对象的构造函数
2.prototype——给原型对象添加方法
主要方法:
1.hasOwnproperty(property)——是否属于本类定义的属性
2.isprototypeof(object)——是否是指定类的prototype
3.propertylsEnumerable(property)——是否可例举的属性
4.toString()——返回对象对应的字符串
5.valueof()——返回对象对应的原始类型值
现在我们具体了解object类的prototype属性,我们先来看一个例子:
var i=new Number(10);
Number.prototype.add=function(a){
return this+a
}
window.alert(i.add(10).add(30));
var b=90;
window.alert(b.add(40));
我们可以看到window.alert(i.add(10).add(30))输出的结果是50,window.alert(b.add(40))输出的结果是150,这是由prototype来实现的,所以的对象都可以调用add()这个方法。
现在我们再解决一个问题:给javascript中的Array对象扩展一个find(val)方法,当一个Array对象调用该方法的时候,如果我们能找到val则返回其下标,否则返回负-1。
var arr1=new Array(3);
arr1[0]="George"
arr1[1]="John"
arr1[2]="Thomas"
//遍历数组
for(var i=0;i<arr1.length;i++){
document.write(arr1[i]+" ");
}
//使用Array提供的方法。颠倒数据
arr1.reverse();
document.write("<br/>");
//遍历该数组
for(var i=0;i<arr1.length;i++){
document.write(arr1[i]+" ");
}
//给Array对象添加一个find(val)方法
Array.prototype.find=function(val){
for(var i=0;i<this.length;i++){
if(val==this[i]){
return i;
}
}
return -1;
}
document.writeln("John 下标="+arr1.find("John"));
我们可以看到输出如图这个结果。