- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对以下规范的 object.create 方法有疑问:
Object.create = function(o, props) {
function F() {}
F.prototype = o;
if (typeof(props) === "object") {
for (prop in props) {
if (props.hasOwnProperty((prop))) {
F[prop] = props[prop];
}
}
}
return new F();
};
在上面代码的第 3 行,我们将 F 对象的原型(prototype)属性设置为 o 参数的原型(prototype)。
我本以为这意味着 o 和 F 都指向同一个原型(prototype),因此指向同一组成员。
但是代码随后继续复制 prop in props 循环中的所有成员。
如果我们继续手动复制所有成员,那么在第 3 行设置原型(prototype)有什么意义?
最佳答案
您的问题中 Object.create
的版本存在错误:循环将属性附加到构造函数 F
(不是返回的对象,或其原型(prototype)),这意味着它们在创建的对象中不可访问。
Object.create
的第二个参数的属性应该被复制到新创建的对象中。 Mozilla documentation for Object.create
像这样说:
If specified and not undefined, an object whose enumerable own properties (that is, those properties defined upon itself and not enumerable properties along its prototype chain) specify property descriptors to be added to the newly-created object, with the corresponding property names.
尝试使用问题中的 Object.create
版本运行以下代码:
o = Object.create(
{a: "prototype's a", b: "prototype's b"},
{a: "object's a"}
);
你会发现 o.a == "prototype's a"
和 o.b == "prototype's b"
, "object's a"
是迷路了。
函数的以下版本可能更有用:
Object.create = function(o, props) {
var newObj;
// Create a constructor function, using o as the prototype
function F() {}
F.prototype = o;
// Create a new object using F as the constructor function
newObj = new F();
// Attach the properties of props to the new object
if (typeof(props) === "object") {
for (prop in props) {
if (props.hasOwnProperty((prop))) {
newObj[prop] = props[prop];
}
}
}
return newObj;
};
让我们用同样的例子试试看:
o = Object.create(
{a: "prototype's a", b: "prototype's b"},
{a: "object's a"}
);
新对象 o
是使用具有属性 a
和 b
的原型(prototype)创建的,它有自己的属性 a
.
我们先看o.b
:o.hasOwnProperty("b")
会返回false
,因为o
没有名为 b
的属性。这就是原型(prototype)出现的地方;因为没有属性 b
它是在原型(prototype)上查找的,因此 o.b === "prototype's b"
。
另一方面,o.hasOwnProperty("a")
将返回 true
,因为 o
确实有一个 a
属性。 o.a == "object's a"
并且没有从原型(prototype)中查找任何内容。
正如 @chuckj's answer 中指出的那样, Object.create
的正确实现比这更复杂。有关详细信息,请参阅 John Resig's post on ECMAScript 5 Objects and Properties .
关于javascript - Object.create 说明,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12295729/
假设有一个创建用户的操作。如果存在指定的电子邮件或用户名,此操作可能会失败。如果它失败了,则需要确切地知道原因。在我看来,有三种方法可以做到这一点,我想知道是否有明显的赢家。 所以,这是一个类用户:
var obj1 = Object.create; console.log(typeof obj1); var obj2 = Object.create(null); console.log(type
I am getting this error after running npm run build yield User.create({^在运行NPM Run Build Year Use
我应该为其他人将从中继承的第一个父对象传递哪个参数,哪个参数更有效 Object.create(Object.prototype) Object.create(Object) Object.creat
我正在尝试使用 JDBC(最新版本)设置 SQL Server 2008 数据库。 我有一个我想一起执行的 setup sql 命令列表: 基本上我做的是: connection.setAutoCom
我正在尝试创建一个 CloudFormation 模板来创建一个 Auto Scaling 组,以便我可以从中启动 2 个实例。 我已经创建了 Auto Scaling 组,但我不知道如何编写用于从
我正在创建我的第一个WordPress网站。我已经在我的网站上安装了Elementor Pro插件。随之而来的一个有利因素是“循环旋转木马”。。。当我把它添加到我的页面时,一切似乎都在工作,但是当我点
create-react-app error 我从终端运行yarn start时收到此错误消息...我尝试了sudo killall node和许多其他过程来清除i-node却没有成功。 我也将我的c
在 CRM 中,当我尝试设置工作流程时,我可以选择与某个实体的创建时间相关的超时。涉及三个字段。 记录创建于 创建于 修改时间 虽然最后一个很明显,但我看不出其他两个之间有任何逻辑上的区别。 最佳答案
我在一次采访中被问到这个问题。我无法回答。 "browserslist": [ ">0.2%", "not dead", "not ie <= 11", "not op_mini all" ] 我可以
这是一个 Rails 新手问题: 当我在模型上调用 create() 时,它会绕过关联的 Controller create 操作吗? 例如,这没有命中我的标签 Controller #create
我不明白这两种特权之间的区别。 我找到了这两种解释,但对我没有帮助。 CREATE TABLE -> Enables a user to create a table owned by that us
我是 SharePoint 工作流的新手。 创建新任务并分配 TaskId 时,我有两个选项: 创建一个新字段来保存 TaskId 创建一个新属性来保存 TaskId。 新属性是一个依赖属性。 我的问
我突然注意到我们的代码库中有一个TDataModuleTestExchange(nil)“构造函数调用”: procedure TDialoogConfigExchange.ButtonTestCli
我有一个具有 TComponent 变量的单元,我在单元初始化时创建此组件,如下所示: var XComp: TComponent; . . . . initialization begin
Composer 是否提供了更新项目创建时使用的包的方法?即,如果我使用以下内容创建一个新的 Laravel 项目 composer create-project --prefer-dist lara
在 Hibernate 中,如果我们将 hbm2ddl.auto 设置为 create/create-drop ,那么它将在启动时删除旧模式并创建新模式。这意味着,它也会删除数据?..我的疑问是,如果
我使用了 create an Automated Build 中的此链接 ( this guide ) . 浏览器错误控制台显示: https://hub.docker.com/v2/reposito
我已经搜索了 msdn 并没有找到答案。我应该知道有什么区别吗? 如果真的没有区别,那么为什么会存在这种冗余? --SQL Server Stored Procedure Syntax CREATE
我有以下内容: var CardViewModel = function (data) { ko.mapping.fromJS(data, {}, this); this.editin
我是一名优秀的程序员,十分优秀!