- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在学习一些 JS,我希望有人能用简单的术语向我解释 Object.getPrototypeOf()
与 .prototype
之间的区别
function ParentClass() {}
function ChildClass() {}
ChildClass.prototype = new ParentClass();
var mychild = new ChildClass();
var myparent = new ParentClass();
# .getPrototypeOf
Object.getPrototypeOf(ChildClass.prototype) // ParentClass {}
Object.getPrototypeOf(mychild) // ParentClass {}
Object.getPrototypeOf(ParentClass.prototype) // {}
Object.getPrototypeOf(myparent) // ParentClass {}
# .prototype
ParentClass.prototype // ParentClass {}
myparent.prototype // undefined
ChildClass.prototype // ParentClass {}
mychild.prototype // undefined
看起来你只能在构造函数上调用 .prototype ?
还有其他区别吗?
最佳答案
function MyConstructor() {}
var obj = new MyConstructor()
Object.getPrototypeOf(obj) === obj.prototype // false
Object.getPrototypeOf(obj) === MyConstructor.prototype // true
MyConstructor.prototype // MyConstructor {}
obj.prototype // undefined
MyConstructor.prototype.constructor === MyConstructor // true
Object.getPrototypeOf(MyConstructor) === Function.prototype // true
<小时/>
关于 JavaScript 原型(prototype)的令人困惑的部分是,有两种不同的东西听起来非常相似。
当你创建一个新对象时,如果用于创建新对象的函数或对象有.prototype方法,那么.prototype
引用的对象将成为新对象的原型(prototype) newObj.__proto__
.
听起来很复杂......让我们进一步分解它。
示例 - 使用函数作为构造函数
当您在函数上使用 new
关键字(即,将该函数用作构造函数)时,该函数的 .prototype 将成为新的 obj.__proto__
。
让我们首先创建一个函数并检查这个 .prototype 属性
function MyConstructor(){
}
console.log(MyConstructor.prototype) // {}
等等... MyConstructor.prototype//{}
- 是不是发生了什么神奇的事情?这个空对象 {}
从哪里来?
这里有两件事:
每当您声明函数时,Javascript 都会自动创建一个 .prototype 对象 - 自动。
该对象不为空。它实际上有一个属性指向创建该对象的函数(对象的“构造函数”)。我们来看看:
console.log(MyConstructor.prototype.constructor);//[函数:MyConstructor]
MyConstructor.prototype.constructor === MyConstructor//true
因此,对于函数来说,.prototype 属性及其关联对象是自动创建的。
还是很困惑吗?让我们在其中添加一些方法,以便更容易地了解发生了什么......
function MyConstructor(){
}
MyConstructor.prototype.func2 = function(){
};
console.log(MyConstructor); // [Function: MyConstructor]
console.log(MyConstructor.prototype); // MyConstructor { func2: [Function] }
MyConstructor.func2(); // TypeError: MyConstructor.func2 is not a function
从上面的代码中我们可以清楚地看到,MyConstructor 和 MyConstructor.prototype 是两个独立的实体。
对象的原型(prototype)(不是 .prototype - 请参阅上面的 A.)是 javascript 用于查找和解析对象中尚不存在的方法的对象(稍后会详细介绍)。
继续上面的内容,当我们从具有 .prototype 属性的函数或对象创建对象时,新创建的对象将拥有引用此 .prototype 对象的 object.__proto__
。
可以通过以下方式访问对象的原型(prototype)
Object.getPrototypeOf(obj)
或已弃用的
obj.__proto__
示例 - 使用函数作为构造函数
让我们使用函数 MyConstructor 作为构造函数来创建一个新对象。
function MyConstructor(){
}
var obj = new MyConstructor()
console.log(Object.getPrototypeOf(obj)); // {}
以下是三个相关的事情:
obj.__proto__
--> MyConstructor.prototype所以obj.__proto__
是MyConstructor.prototype
。证明如下:
MyConstructor.prototype === Object.getPrototypeOf(obj) // true
让我们向 MyConstructor 添加一个方法
function MyConstructor(){
this.func1 = function(){
console.log("this is func1");
};
}
var obj = new MyConstructor();
obj.func1(); // this is func1
从上面你可以看到,你可以调用构造函数中声明的方法。事实上,如果我们看一下,由于 javascript 创建对象的方式,我们声明的方法 func1 实际上是 obj 的一部分。
console.log(obj); // MyConstructor { func1: [Function] }
我们还可以通过将方法添加到原型(prototype)中来添加 obj 可以使用的方法。例如
MyConstructor.prototype.func2 = function(){
console.log("this is func2");
};
obj.func2(); // this is func2
MyConstructor 和 MyConstructor.prototype 方法将可用于使用此设置使用 MyConstructor 创建的所有对象。
有用的引用资料
Definitive Guide to Object-Oriented JavaScript
Understanding JavaScript: Inheritance and the prototype chain
关于javascript - Object.getPrototypeOf() 与 .prototype,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38740610/
我遵循了一本名为“Sitepoint Full Stack Javascript with MEAN”的书中的教程,我刚刚完成了第 6 章,应该已经创建了一个带有“数据库”的“服务器”。数据库只不过是
在 Jquery 中,我创建两个数组,一个嵌入另一个数组,就像这样...... arrayOne = [{name:'a',value:1}, {name:'b',value:2}] var arra
这个问题在这里已经有了答案: What is the explanation for these bizarre JavaScript behaviours mentioned in the 'Wa
我被放在别人的代码上,有一个类用作其他组件的基础。当我尝试 ng serve --aot(或 build --prod)时,我得到以下信息。 @Component({ ...,
我正在测试一些代码,并使用数据创建了一个 json 文件。 问题是我在警报中收到“[object Object],[object Object]”。没有数据。 我做错了什么? 这是代码:
我想打印 [object Object],[object Object] 以明智地 "[[{ 'x': '1', 'y': '0' }, { 'x': '2', 'y': '1' }]]"; 在 ja
我有一个功能 View ,我正在尝试以特殊格式的方式输出。但我无法让列表功能正常工作。 我得到的唯一返回是[object Object][object Object] [object Object]
在使用优秀的 Sim.js 和 Three.js 库处理 WebGL 项目时,我偶然发现了下一个问题: 一路走来,它使用了 THREE.Ray 的下一个构造函数: var ray = new THRE
我正在使用 Material UI 进行多重选择。这是我的代码。 {listStates.map(col => (
我的代码使用ajax: $("#keyword").keyup(function() { var keyword = $("#keyword").val(); if (keyword.
我遇到了下一个错误,无法理解如何解决它。 Can't resolve all parameters for AuthenticationService: ([object Object], ?, [o
我正在尝试创建一个显示动态复选框的表单,至少应选中其中一个才能继续。我还需要获取一组选中的复选框。 这是组件的代码: import { Component, OnInit } from '@angul
我正在开发 NodeJs 应用程序,它是博客应用程序。我使用了快速验证器,我尝试在 UI 端使用快速闪存消息将帖子保存在数据库中之前使用闪存消息验证数据,我成功地将数据保存在数据库中,但在提交表单后消
我知道有些人问了同样的问题并得到了解答。我已经查看了所有这些,但仍然无法解决我的问题。我有一个 jquery snipet,它将值发送到处理程序,处理程序处理来自 JS 的值并将数据作为 JSON 数
我继承了一个非常草率的项目,我的任务是解释为什么它不好。我注意到他们在整个代码中都进行了这样的比较 (IQueryable).FirstOrDefault(x => x.Facility == fac
我只是在删除数组中的对象时偶然发现了这一点。 代码如下: friends = []; friends.push( { a: 'Nexus', b: 'Muffi
这两个代码片段有什么区别: object = nil; [object release] 对比 [object release]; object = nil; 哪个是最佳实践? 最佳答案 object
我应该为其他人将从中继承的第一个父对象传递哪个参数,哪个参数更有效 Object.create(Object.prototype) Object.create(Object) Object.creat
我在不同的对象上安排不同的选择器 [self performSelector:@selector(doSmth) withObject:objectA afterDelay:1]; [self per
NSLog(@"%p", &object); 和 NSLog(@"%p", object); 有什么区别? 两者似乎都打印出一个内存地址,但我不确定哪个是对象的实际内存地址。 最佳答案 这就是我喜欢的
我是一名优秀的程序员,十分优秀!