草庐IT

拷贝构造

全部标签

javascript - 在构造一个集合后让 backbone.js 运行一个函数?

我可能在这里完全遗漏了一些东西,但我有以下内容:封装“所有”数据的模型(从一个URL加载的所有JSON)该模型有一个(或多个)集合,它正在使用构建时获得的数据进行实例化一些我想在数据初始化和加载时在集合上运行的代码我的问题是关于组合集合的。我可以在Collection的范围之外执行此操作,但我宁愿将其封装(否则将其作为带有初始化程序等的“类”有什么意义)。我想我可以将该代码放在initialize()函数中,但是它在填充模型之前运行,所以我无法访问构成集合(this.models为空)。然后我想我可以绑定(bind)一个事件,但是初始化后没有触发任何事件。如果我使用fetch从它自己的

javascript - 构造函数与闭包?

这2个对象a使用构造函数创建,b使用闭包创建,究竟有什么不同?属性__proto__是否对使用闭包无法实现的任何事情有用?我应该在不同的情况下使用这些技术吗?内存使用有区别吗?(jsFiddle)window.MODULE={};MODULE.constructor=function(){this.publicVariable=10;};MODULE.constructor.prototype.publicMethod=function(){returnthis.publicVariable;};//-------------------------------//MODULE.clo

javascript - 对于 JavaScript 多维数组的深拷贝,深入一层似乎就足够了。这是真的吗?

注意:我只是一个编码新手,所以这个问题的核心可能存在明显的错误或误解。本质上,我需要在JavaScript中“按值”深度复制多维数组到未知深度。我原以为这需要一些复杂的递归,但似乎在JavaScript中您只需要深复制一个级别就可以按值复制整个数组。举个例子,这是我的测试代码,使用了一个故意复杂的数组。functiontest(){vararr=[['ok1'],[],[[],[],[[],[[['ok2'],[]]]]]];varcloned=cloneArray(arr);arr='';//Deletetheoriginalalert(cloned);}functioncloneA

javascript - 为什么 getPrototypeOf() 在 JavaScript 中返回不正确的构造函数?

varprotoRabbit={size:"small"};varfastRabbit=Object.create(protoRabbit);console.log(Object.getPrototypeOf(fastRabbit));以上片段打印:Object{size:"small"}这不应该打印protoRabbit{size:"small"}吗?我的理解中缺少什么? 最佳答案 打印在对象前面的名称是构造函数的名称。您的对象protoRabbit具有构造函数Object,因为您使用对象字面量创建了此对象:varprotoRab

javascript - 我可以创建一个 Array.isArray() 返回 true 的对象而不使用 Array 构造函数或数组文字吗?

通过将其原型(prototype)设置为Array.prototype,我可以轻松地使一个普通对象看起来像一个数组:constobj={};Reflect.setPrototypeOf(obj,Array.prototype);(我知道神奇的length属性和稀疏数组也存在一些问题,但这不是这个问题的重点。)我想让Array.isArray(obj)返回true(当然不修改Array.isArray()方法)。MDNpolyfillforArray.isArray()如下:if(!Array.isArray){Array.isArray=function(arg){returnObje

javascript - 如果一个对象只有一个实例,我还应该使用构造函数吗?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭6年前。Improvethisquestion我一直深入JS世界,遇到了3种不同的方法来开发网站的前端购物车:带有原型(prototype)函数的构造函数varcart=function(){this.items={}}cart.prototype.increaseItemQty=function(partNumber){if(this.items[partNumber]){this.items[partNumber].qty+=1;

javascript - 类与构造函数与工厂函数中的澄清需要

我正在研究ES6类,我的最终目标是了解类、构造函数和工厂函数之间的区别。我当前的理解是构造函数和类基本上使用相同的设计模式,类只是构造函数的新语法。基于这个假设,我正在尝试创建一些示例来显示类/构造函数和工厂函数之间的对比。在下面的示例中,我旨在返回新对象和一些继承的方法。我的第一个示例使用类语法非常简单。示例#1:类classPerson{constructor(name,age,location,occupation){this.name=name;this.age=age;this.location=location;this.occupation=occupation;}pri

javascript - Javascript 中的构造函数属性是否有好的用例?

首先,这个问题不是“constructor属性的作用是什么?”-关于它到底是什么以及它是如何工作的,有很多很好的文档:它是对创建对象的函数的引用(可能继承自其原型(prototype))。我更有兴趣了解此属性的常见用例。这在理论上似乎一切都很好,但是您什么时候真正需要对构造您的对象的函数的引用?一些想法是:也许我想克隆它。我可以再次调用构造函数并且获取我的对象的另一个实例。这当然不会奏效因为您可能会创建对象的实例原型(prototype),而不是对象本身;再加上一个更受欢迎的方法是创建一个新对象并设置该对象的原型(prototype)。也许你可以用它来弄清楚对象的“类型”是。这看起来很

javascript - 如何从构造函数中删除函数?

如何从构造函数中删除一个函数?如果Person构造函数中有一个名为greet的函数,我该如何删除该函数?functionPerson(name){this.name=name;this.greet=functiongreet(){alert("Hello,"+this.name+".");};}我想要的结果是:functionPerson(name){this.name=name;} 最佳答案 deletethis.greet或varpersonInstance=newPerson();deletepersonInstance.gr

javascript - Crockford 关于构造函数调用模式的代码

下面的代码几乎与道格拉斯·克罗克福德(DouglasCrockford)的精湛著作《JavaScript:好的部分》第29-30页中的一些代码相同。唯一的区别是他像这样添加了get_status属性:Quo.prototype.get_status=function(){this.status=string;}我的问题是为什么他的代码运行正常,但我在下面的小改动会导致出现错误,提示myQuo没有get_status方法?varQuo=function(string){this.status=string;}Quo.get_status=function(){returnthis.sta