当前位置:Gxlcms > JavaScript > javascript自定义对象的三种类型方法代码详解

javascript自定义对象的三种类型方法代码详解

时间:2021-07-01 10:21:17 帮助过:3人阅读

1)JS中可以为对象定义三种类型的方法:私有方法、实例方法和类方法,与Java类似:

私有方法只能在对象内部使用

实例方法必须在对象实例化后才能使用

类方法可以直接通过类名去使用

注意:方法的定义不能通过前面所说的index方式进行。

2)定义私有方法

私有方法必须在构造函数体内定义,而且只能在构造函数体内使用。

语法格式:function methodName(arg1,…,argN){ }

例如:

function User(name){
 
this.name=name;
 
function getNameLength(nameStr){
 
return nameStr.length;
 
}
 
this.nameLength=getNameLength(this.name);
 
}

3)定义实例方法,目前也可以使用两种方式:

prototype方式,在构造函数外使用,语法格式:

functionName.prototype.methodName=method;

或者

functionName.prototype.methodName=function(arg1,…,argN){};

this方式,在构造函数内部使用,语法格式:

this.methodName=method;

或者

this.methodName=function(arg1,…,argN){};

上面的语法描述中,method是外部已经存在的一个方法,methodName要定义的对象的方法,意思就是将外部的一个方法直接赋给对象的某个方法。

以function(arg1,…,argN){}的方式定义对象方法是开发人员应该掌握的。

定义实例方法的一些例子:例子1

function User(name){
 
this.name=name;
 
this.getName=getUserName;
 
this.setName=setUserName;
 
}
 
function getUserName(){
 
return this.name;
 
}
 
Function setUserName(name){
 
this.name=name;
 
}

定义实例方法的一些例子:例子2

function User(name){
 
this.name=name;
 
this.getName=function(){
 
return this.name;
 
};
 
this.setName=function(newName){
 
this.name=newName;
 
};
 
}

定义实例方法的一些例子:例子3

function User(name){
 
this.name=name;
 
}
 
User.prototype.getName=getUserName;
 
User.prototype.setName=setUserName();
 
function getUserName(){
 
return this.name;
 
}
 
Function setUserName(name){
 
this.name=name;
 
}

定义实例方法的一些例子:例子4

4)定义类方法

类方法需要在构造函数外面定义,可以直接通过构造函数名对其进行引用。

语法格式:

functionName.methodName=method;

或者

functionName.methodName=function(arg1,…,argN){};

例子:

function User(name){
 
this.name=name;
 
}
 
User.getMaxAge=getUserMaxAge;
 
function getUserMaxAge(){
 
return 200;
 
}

或者

User.getMaxAge=function(){return 200;};
alert(User.getMaxAge());

以上就是javascript自定义对象的三种类型方法代码详解的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行