您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

JavaScript面向对象继承方法

2025/12/15 21:06:21发布49次查看
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". //定义一个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". //定义一个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面向对象的继承,没有哪种方法绝对的好,也没有哪种方法绝对的不好。依个人情况喜好而定。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product