- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在为一个小项目设置我自己的 JavaScript 基础对象。我希望能够设置一些简单的对象,我的更复杂的对象可以从中继承功能。
我一直在网上学习一些教程( http://desalasworks.com/article/object-oriented-javascript-inheritance/ ),并具有我需要的基本扩展行为,请参阅此问题的代码部分以了解基本框架设置。
我有一个 TestModel 类,它继承了 Model 的功能。我可以像这样创建两个新实例:
var test_model_1 = new TestModel();
var test_model_2 = new TestModel();
然后我可以在它们上设置一些数据:
test_model_1.set({test:'Test1'});
test_model_2.set({test:'Test2'});
我可以获得两个对象的结果:
test_model_1.get() //test will = Test1
test_model_2.get() //test will = Test2
我现在仅向 test_model_1 添加监听器:
test_model_1.addListener(function(data){
console.log(data);
});
并在 test_model_2 上设置调用:
test_model_2.set({test:'Some data that should not be seen in the console.log'});
test_model_1 监听器被触发并将数据发送到控制台日志。由于监听器仅添加到 test_model_1 对象,并且在 test_model_2 对象上调用该集合,因此不应发生这种情况。
我的 Model 类允许在该类的任何实例上调用 set 时调用所有监听器,这有什么问题吗?
Object.extend = function (superClass, definition) {
var subClass = function () {
};
// Our constructor becomes the 'subclass'
if (definition.constructor !== Object) {
subClass = definition.constructor;
}
subClass.prototype = new superClass();
for (var prop in definition) {
if (prop != 'constructor')
subClass.prototype[prop] = definition[prop];
}
// Keep track of the parent class
// so we can call its constructor too
subClass.superClass = superClass;
return subClass;
};
Model = Object.extend(Object, {
data: {},
listener: [],
constructor: function (data) {
var root = this;
this.data = data;
},
get: function () {
return this.data;
},
set: function (data) {
this.data = data
var arrayLength = this.listener.length;
for (var i = 0; i < arrayLength; i++) {
this.listener[i](data);
}
},
addListener: function (callback) {
if (typeof callback == 'function') {
this.listener.push(callback);
}
}
});
TestModel = Object.extend(Model, {
constructor: function () {
TestModel.superClass.call(this, {test: 'some default data'});
},
addListener: function (callback) {
if (typeof callback == 'function') {
this.listener.push(callback);
}
}
});
最佳答案
这是一个简单的修复,我需要在模型构造函数中创建一个监听器实例,如果不这样做,监听器将位于 .prototype 对象范围内,并在扩展它的所有对象之间共享。
Model = Object.extend(Object, {
data: {},
listener: [],
constructor: function (data) {
this.data = data;
this.listener = []; //set up listener for this instance
},
get: function () {
return this.data;
},
set: function (data) {
this.data = data
var arrayLength = this.listener.length;
for (var i = 0; i < arrayLength; i++) {
this.listener[i](data);
}
},
addListener: function (callback) {
if (typeof callback == 'function') {
this.listener.push(callback);
}
}
});
关于具有监听器回调的 JavaScript OO 类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25008024/
我相信 OO,但不至于应该使用不适当的设计/实现来实现“OO 兼容”。 那么,如何应对 Serlvet/EJB/DataContainer 分层架构: Servlet 接收请求并调用“业务层”(例如
我有一个员工分为两类(国内和国际)。我还有一个类Refund,是用来给员工退款的。我有一个名为银行账户的类,由 Refund 类用于退款。 现在我的直接设计是这样的: 员工界面,分国内和国际2个子类型
为什么基于类的 OO 而不是基于原型(prototype)的 OO 如此受欢迎?他们在学校教后者吗?尽管 Javascript 是基于原型(prototype)的,但大多数人主要在功能上使用它,或者通
为什么基于类的 OO 而不是基于原型(prototype)的 OO 如此受欢迎?他们在学校教后者吗?尽管 Javascript 是基于原型(prototype)的,但大多数人主要在功能上使用它,或者通
我找不到主要区别。我很困惑什么时候可以使用继承,什么时候可以使用子类型。我找到了一些定义,但它们不是很清楚。 在面向对象编程中,子类型化和继承有什么区别? 最佳答案 除了已经给出的答案,这里还有一个
我想在类中动态定义方法。我正在写一个跟踪器,比下面的框架稍微复杂一些,它也有状态意识,但这与我的问题无关。我写了一个 TraceSlave 类,它带有调用 sprintf 的跟踪方法,用文本\n 替换
如果你看过Going Deep shows of the Channel9最近,一个经常被提及的话题是mathematical duality在编程中。 TomasP 有一个不错的blog post关
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 8 年前。 Improve
我是软件设计原则的忠实粉丝,例如 固体 和 干 .面向对象软件设计还有哪些其他原则? 笔记。我不是在寻找诸如“评论您的代码”之类的答案,而是在寻找 OO 设计原则,例如 Uncle Bob 讨论的那些
我找不到主要区别。我很困惑什么时候可以使用继承,什么时候可以使用子类型。我找到了一些定义,但它们不是很清楚。 面向对象编程中的子类型和继承有什么区别? 最佳答案 除了已经给出的答案,这里还有一个 li
这个问题已经有答案了: Javascript: Do I need to put this.var for every variable in an object? (6 个回答) 已关闭 9 年前。
我正在构建一个应用程序,该应用程序在一个对象内有一个对象数组,而它的自身位于一个数组中。我希望能够从子对象访问父对象的属性。我知道我可以简单地通过索引引用父级,如下所示: var parents =
我有一个像这样的html页面 和 2 个像这样的 JavaScript 文件 /// /// /// $(document).ready(fu
我正在尝试用 javascript 做一个巨大的 Web 应用程序,如果我不想搞乱一切,我想我必须以面向对象的方式来做。因此,我进行了很多搜索,发现了很多在 JS 中声明类和创建实例的不同方法,例如环
我在理解 OO 模式如何工作时遇到了一些问题,我的讲师给了我以下问题,但我思考了一整天后无法解决它 我的问题的场景。 有一个名为“ShapeManager”的类,用于管理 Shape 对象。名为“Sh
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 可以用事实和引用来回答它. 1年前关闭。 Improve this
我正在阅读科学 paper关于 Robert martin 编写的 OO Design Quality Metrics。 在他的论文中,他描述了“一组指标,可用于衡量面向对象设计的质量,根据该设计的子
我有一个与 OOP 相关的问题。我有一个界面,说: class MyInterface { public int getValue(); } 在我的项目中,这个接口(interface)由 7
是否有更好的Pythonic/面向对象方法来选择在运行时执行哪个特定类方法,具体取决于对象的类型,因为使用 type() 方法不被认为优雅(?) 我为我正在使用的三种数据类型编写了以下代码。它基本上将
就 Perl OO 而言,-> 到底做了什么? 例如我打了一个主电话: $result = a::b->mymethod( ); 在我定义 mymethod() 的包中,我使用了以下内容: m
我是一名优秀的程序员,十分优秀!