javaScript面向对象继承方法经典实现_基础知识

JavaScript的出现已经将近20多年了,但是对这个预言的褒贬还是众说纷纭。很多人都说JavaScript不能算是面向对象的变成语言。但是JavaScript的类型非常松散,也没有编译器。这样一来给了程序员很大的自由,也带来了一些缺陷。

虽然JavaScript不算是一门面向对象的语言。但是我们可以模仿着其他语言实现面向对象的方式来实现JavaScript的面向编程。

下面是JavaScript教程中非常经典的继承方法。

复制代码 代码如下:

//定义一个Pet对象。通过这一个名称和数量的腿。
var Pet = function (name,legs) {
this.name = name; //Save ths name and legs values.
this.legs = legs;
};

//创建一个方法,显示了Pet的名字和数量的腿。
Pet.prototype.getDetails = function () {
return this.name + " has " + this.legs + " legs ";
}

//定义一个Cat对象,继承从Pet。
var Cat = function (name) {
Pet.call(this,name,4); //调用这个父对象的构造函数
};

//这条线执行继承从Pet。
Cat.prototype = new Pet();

//增加一个动作方法的猫
Cat.prototype.action = function () {
return "Catch a bird";
};

//创建一个实例petCat的猫。
var petCat = new Cat("felix");

var details = petCat.getDetails();
console.log(details) //"felix has 4 legs".
var action = petCat.action();
console.log(action) //"Catch a bird".
petCat.name = "sylvester"; //改变petCat的名字
petCat.legs = 7; //改变petCat腿的数量
details = petCat.getDetails();
console.log(details) //"sylvester has 7 legs".

上述方法虽然执行起来没有太大的问题,但是代码整体风格略显臃肿,并不很优雅。在外面还是可以对属性进行修改。这种方法没有对继承的属性进行保护。下面一种方法,省去的new和prototype,利用“函数继承”的特性实现。

复制代码 代码如下:

//定义一个pet对象。通过这一个名称和数量的腿。
var pet = function (name,legs) {
//创建一个对象that,其中名字是可以改的,但是腿数不可以改,实现了变量私有化。
var that = {
name : name,
getDetails : function () {
return that.name + " has " + legs + " legs ";
}
};

return that;
}

//定义一个cat对象,继承从pet。
var cat = function (name) {
var that = pet(name,4); //从pet中继承属性

//cat中增加一个action的方法。
that.action = function () {
return "Catch a bird";
}

return that;

}

//创建一个petCat2;
var petCat2 = cat("Felix");

var details = petCat2.getDetails();
console.log(details) //"felix has 4 legs".
var action = petCat2.action();
console.log(action) //"Catch a bird".
petCat2.name = "sylvester"; //我们可以改变名字。
petCat2.legs = 7; //但是不可以改变腿的数量
details = petCat2.getDetails();
console.log(details) //"sylvester has 4 legs".

温馨提示:使用原型继承的好处是内存效率高,不管它被继承多少次,对象的原型属性和方法只被保存一次。函数继承的时候,每个新的实例都会创建重复的属性和方法。若创建很多大的对象,内存消耗会很大。解决方法是把较大的属性或方法保存在一个对象中,并将其作为参数传给构造函数。这样所有实例就会使用一个对象资源,而不是创建自己的版本了。

上面两种方法都可以轻松实现JavaScript面向对象的继承,没有哪种方法绝对的好,也没有哪种方法绝对的不好。依个人情况喜好而定。这两种方法也不是唯一的,欢迎大家评论补充哟!~

时间: 2024-12-26 05:55:48

javaScript面向对象继承方法经典实现_基础知识的相关文章

简介JavaScript中toTimeString()方法的使用_基础知识

 该方法返回一个Date对象在人类可读的形式时间部分.语法 Date.toTimeString() 下面是参数的详细信息:     NA 返回值: 返回Date对象的人类可读形式的时间部分.例子: <html> <head> <title>JavaScript toTimeString Method</title> </head> <body> <script type="text/javascript"&g

简介JavaScript中valueOf()方法的使用_基础知识

 JavaScript的Boolean.valueOf()方法返回指定 Boolean对象的原始值.语法 boolean.valueOf() 下面是参数的详细信息:     NA 返回值: 返回指定Boolean对象的原始值.例子: <html> <head> <title>JavaScript valueOf() Method</title> </head> <body> <script type="text/jav

详解JavaScript中shift()方法的使用_基础知识

JavaScript数组shift()方法删除数组中的第一个元素,并返回该元素.语法 array.shift(); 下面是参数的详细信息:     NA 返回值: 返回数组中删除单个值.例子: <html> <head> <title>JavaScript Array shift Method</title> </head> <body> <script type="text/javascript">

简介JavaScript中fixed()方法的使用_基础知识

 此方法会导致就好像它是在一个<tt>的标签被显示在固定间距的字体的字符串.语法 string.fixed( ) 下面是参数的详细信息:     NA 返回值:     返回字符串的<tt>标签 例子: <html> <head> <title>JavaScript String fixed() Method</title> </head> <body> <script type="text/j

简介JavaScript中search()方法的使用_基础知识

 此方法执行搜索正则表达式,String对象之间的匹配.语法 string.search(regexp); 下面是参数的详细信息:     regexp : 正则表达式对象.如果非RegExp对象obj传递,它是隐式通过使用new RegExp(obj) 转换为RegExp 返回值:     如果成功的话,搜索将返回字符串内的正则表达式的索引.否则,它返回 -1. 例子: <html> <head> <title>JavaScript String search() M

简介JavaScript中getUTCMonth()方法的使用_基础知识

 javascript Date.getUTCMonth()方法返回按照通用时间在指定日期的月份.由getUTCMonth返回的值是0和11之间的整数对应的月份. 0代表一月,1代表二月,2表 示三月份,依此类推.语法 Date.getUTCMonth() 下面是参数的详细信息:     NA 返回值: 按照通用时间返回指定日期的月份.例子: 下面的例子打印当前时间变量hrs的月份部分. <html> <head> <title>JavaScript getUTCMon

简介JavaScript中charAt()方法的使用_基础知识

 这个方法返回从指定索引的字符. 字符串中的字符进行索引从左向右.第一个字符的索引是0,并且在一个叫 stringName字符串的最后一个字符的索引是stringName.length- 1.语法 string.charAt(index); 下面是参数的详细信息:     index: 介于0和1比串的长度以下的整数. 返回值: 返回从指定索引的字符.例子: <html> <head> <title>JavaScript String charAt() Method&l

简介JavaScript中strike()方法的使用_基础知识

 这种方法会导致一个字符串显示为突出的文字,就好像它是显示在<strike>标签.语法 string.strike( ) 下面是参数的详细信息:     NA 返回值:     返回字符串带有<strike>标签. 例子: <html> <head> <title>JavaScript String strike() Method</title> </head> <body> <script type=&

简介JavaScript中substring()方法的使用_基础知识

 该方法返回一个String对象的一个子集.语法 string.substring(indexA, [indexB]) 下面是参数的详细信息:     indexA : 介于0和1小于字符串的长度的整数.     indexB : (可选)介于0和字符串的长度的整数. 返回值:     substring方法返回基于给定参数的新的子字符串. 例子: <html> <head> <title>JavaScript String substring() Method<