我试图拥有一个通用的“List”类,它将具有:

>物业:物品 – 这将是一系列“过去”
>方法:Add() – 它将被抽象并由特定的“List”对象实现
>方法:Count() – 返回“items”的数量

然后创建将从“List”继承的子类

//Class 'List'
function List(){
    this.Items = new Array();
    this.Add = function(){ alert('please implement in object') }
}

//Class CDList - which inherits from 'List'
function CDList(){
    this.Add = function(Artist){
        this.Items.push(Artist)
    }
}
CDList.prototype = new List();
CDList.prototype.constructor = CDList;

//Create a new CDList object
var mydiscs = new CDList();
mydiscs.Add('Jackson');
mydiscs.Count()  <-- this should be 1


//Create a second CDList object
var mydiscs2 = new CDList();
mydiscs2.Add('Walt');
mydiscs2.Add('disney');
mydiscs2.Count()  <-- this should be 2

..但这似乎为所有’CDList’实例创建一个共享的’项目’列表.我需要以某种方式为每个“CDList”实例添加一个新的“Items”列表的继承实例.

我该怎么做?

*我在这个例子中使用’项目’列表作为例子.我希望能够在我的子类中为任何类型的继承属性新的实例 – 不一定是Array对象.

谢谢你们!

解决方法

只有一个数组,因为你只创建一个.该数组附加到“CDList”的原型,因此在所有实例之间共享.

要解决这个问题:不要将它附加到原型,而是附加到实例.这只能在施工时完成:

// This is the constructor of the parent class!
function List() {
    this.Items = new Array();
}

// Add methods to the prototype,not to the instance ("this")
List.prototype.Add = function() { alert('please implement in object'); };

// Constructor of the child
function CDList() {
    List.call(this); // <-- "super();" equivalent = call the parent constructor
}

// "extends" equivalent = Set up the prototype chain
// Create a new,temporary function that has no other purpose than to create a
// new object which can be used as the prototype for "CDList". You don't want to
// call "new List();",because List is the constructor and should be called on
// construction time only. Linking the prototypes directly does not work either,// since this would mean that overwriting a method in a child overwrites the
// method in the parents prototype = in all child classes.
var ctor = function() {};
ctor.prototype = List.prototype;
CDList.prototype = new ctor();
CDList.prototype.constructor = CDList;

// Overwrite actions
CDList.prototype.Add = function(Artist) {
    this.Items.push(Artist);
};

演示:http://jsfiddle.net/9xY2Y/1/

一般的概念是:每个实例必须具有自己的副本(在这种情况下就像“Items”数组))必须创建并附加到构造时的“this”(=实例),即在执行新的List( )或新的CDList().可以在实例之间共享的一切都可以附加到原型.这实际上意味着像“添加”功能这样的属性完全一次创建,然后被所有实例使用(导致原始问题).

连接原型时,您不得直接链接(通常),例如:

CDList.prototype = List.prototype;
DVDList.prototype = List.prototype;

// Now add a new function to "CDList"
CDList.prototype.Foo = function() {alert('Hi'); };

因为“List”,“CDList”和“DVDList”三个函数的原型彼此直接链接,所以它们都指向一个原型对象,就是List.prototype.所以,如果你添加一些CDList.prototype,你实际上将它添加到List.prototype – 这也是“DVDList”的原型.

var dvd = new DVDList();
dvd.Foo(); // <-- alerts "hi" (oops,that wasn't intended...)

将原型链接到父类的新实例的诀窍是什么?

CDList.prototype = new List();

这将创建一个类型为“List()”的新对象,其特征是功能“List()”的原型链接到新对象,使您能够直接在对象上调用原型的属性:

var l = new List();
alert( l.hasOwnProperty("Add") );  // <-- yields "false" - the object l has no
                                   // property "Add"
l.Add("foo"); // <-- works,because the prototype of "List" has a property "Add"

但是,请记住,我们打算使用函数“List()”的主体在每个实例的基础上创建像这个数组“Items”的东西?这是你放置任何“构造函数”代码的地方,例如

function User(userId) {
    $.getJSON('/user/' + userId,...
}

function Admin() {}
Admin.prototype = new User( // ... Now what?

一个非常干净的解决方案是使用另一个函数来创建一个原型对象:

var ctor = function() {}; // <-- does nothing,so its super safe
                          // to do "new ctor();"

现在可以直接链接原型,因为我们永远不会添加任何东西到ctor.prototype:

ctor.prototype = List.prototype;

如果我们这样做:

CDList.prototype = new ctor();

“CDList()”的原型变成类型“ctor”的新对象,它没有自己的属性,但可以扩展.通过一个新的“添加”功能:

CDList.prototype.Add = function() { /* CD specific code! */ };

但是,如果您不向此新的原型对象添加“Add”属性,则“ctor()”的原型将会启动 – 这是“List()”的原型.这是所需的行为.

此外,“List()”中的代码现在只有当您执行新的List()或直接从另一个函数(通过List.call(this);的子类中)调用它)时才执行.

Javascript属性继承的更多相关文章

  1. Swift 字符串替换/过滤/切割/拼接

    替换为/结果过滤过滤掉单个字符/结果过滤掉开头和结尾的空白结果切割对字符串使用/作为分隔符来切割,不允许空字符串使用split函数结果是一个数组对字符串使用/作为分隔符来切割,允许空字符串结果拼接结果

  2. Swift开发教程--字符串的操作

    替换把?替换为/结果

  3. swift 网络搜索热词排行

    1.使用www.showapi.com上的接口,需要注册添加一个App,这样才能获取appid和secret密钥,调用前需要订购套餐(选免费的就可以了);2.外部库Podfile文件内容,SnapKit这里暂时不需要用到:3.桥接头文件参考:http://www.jb51.cc/article/p-pcleyxep-te.html4.AppTransportSecurityhasblockedac

  4. 如何在Swift中打乱数组?

    如何随机化或混洗Swift中的数组中的元素?例如,如果我的数组包括52张扑克牌,我想洗牌,以便洗牌。这个答案详细说明了如何在Swift的各种版本中添加Fisher-Yatesshuffle。Swift3版本是最宽松的,但是它们至少可以用于数组。每个Swift版本的命名和行为与该版本的mutating和nonmutating排序方法相匹配。

  5. unit-testing – 如何在Swift中对NSFetchedResultsController进行单元测试

    我有一个Swift应用程序,它使用NSFetchedResultsController从持久存储中获取List对象:它的工作方式与预期的一样,我将List对象描述打印到控制台.我想为我的应用程序编写一些单元测试,所以我创建了扩展XCTestCase的类.代码编译没有问题,测试运行,但不幸的是我无法在该上下文中获取List对象.我在控制台中获得的所有内容都是List对象的数量和致命错误:线路上升:我

  6. swift – 检查自定义对象数组是否包含特定的自定义对象

    说我有一个非常简单的Person类我希望将一个这样的人的集合存储在一个属性中,该属性是一个Person类的数组,类型为Person也许我实现如下问题:我如何检查people.list是否包含实例alex,好吗?

  7. swift – 使用反射来设置对象属性,而不使用setValue forKey

    在Swift中,不可能使用.setValue(…)>可空类型字段,如Int?>具有枚举类型的属性>一个可空对象的数组,如[MyObject?]这有一个解决方法,也就是通过覆盖对象本身中的UnVersionKey方法的setValue.因为我正在写一个基于反射的通用对象映射器.请参阅EVReflection我想尽量减少这种手动映射.是否有其他方式自动设置这些属性?

  8. Swift Sliceable上的递归

    事实证明,有一个通用的解决方案.您需要添加这些通用要求:对于发布的问题,这给出了:这是任何切片上有用的通用缩减:我不能相信这一点,Apple开发论坛上的解决方案是posted.令人遗憾的是,通用要求如此涉及到这样一个基本操作–它几乎不直观!

  9. uitableview – 使用Swift的“使用未解析的标识符”

    我正在重写我在Swift中的一个应用程序,它显示SouthKohala的实时天气数据.爱Swift到目前为止!

  10. Android Checkbox listview选择全部(禁用/启用)

    参见英文答案>SelectingAllItemsinaListviewoncheckboxselect4个我想禁用/启用listview中的所有复选框.infact想通过单击顶部复选框来选择所有行为.谢谢解决方法这是我最终工作的地方,我正在使用游标适配器,而不仅仅是我的列表项的Arraylistadapter:list.getChildCount不起作用,因为它似乎只计算立即绘制的内容(不是屏幕外

随机推荐

  1. js中‘!.’是什么意思

  2. Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  3. 基于JavaScript编写一个图片转PDF转换器

    本文为大家介绍了一个简单的 JavaScript 项目,可以将图片转换为 PDF 文件。你可以从本地选择任何一张图片,只需点击一下即可将其转换为 PDF 文件,感兴趣的可以动手尝试一下

  4. jquery点赞功能实现代码 点个赞吧!

    点赞功能很多地方都会出现,如何实现爱心点赞功能,这篇文章主要为大家详细介绍了jquery点赞功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. AngularJs上传前预览图片的实例代码

    使用AngularJs进行开发,在项目中,经常会遇到上传图片后,需在一旁预览图片内容,怎么实现这样的功能呢?今天小编给大家分享AugularJs上传前预览图片的实现代码,需要的朋友参考下吧

  6. JavaScript面向对象编程入门教程

    这篇文章主要介绍了JavaScript面向对象编程的相关概念,例如类、对象、属性、方法等面向对象的术语,并以实例讲解各种术语的使用,非常好的一篇面向对象入门教程,其它语言也可以参考哦

  7. jQuery中的通配符选择器使用总结

    通配符在控制input标签时相当好用,这里简单进行了jQuery中的通配符选择器使用总结,需要的朋友可以参考下

  8. javascript 动态调整图片尺寸实现代码

    在自己的网站上更新文章时一个比较常见的问题是:文章插图太宽,使整个网页都变形了。如果对每个插图都先进行缩放再插入的话,太麻烦了。

  9. jquery ajaxfileupload异步上传插件

    这篇文章主要为大家详细介绍了jquery ajaxfileupload异步上传插件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. React学习之受控组件与数据共享实例分析

    这篇文章主要介绍了React学习之受控组件与数据共享,结合实例形式分析了React受控组件与组件间数据共享相关原理与使用技巧,需要的朋友可以参考下

返回
顶部