草庐IT

Constructor

全部标签

javascript - 为什么构造函数不是构造函数?

考虑以下片段:​f=function(){};f.prototype={};thing=newf;我惊讶地发现thing.constructor是Object()。(参见fiddlehere。)为什么thing.constructor不是函数f? 最佳答案 因为您已经将f的原始prototype对象完全替换为普通对象。它是原始的prototype对象,它通过.constructor属性保存对f的引用。使用对象字面量语法创建的对象的构造函数将是Object构造函数。要取回它,您需要手动将其放在那里。f=function(){};f.p

JavaScript - instanceof 没有按照我的预期进行

如果我错了,请原谅我,但我认为这样做:functionMyObject(){return{key:'value',hello:function(){console.log('world');}};}varobj=newMyObject();我创建了一个MyObject类型的新实例。但是,如果我这样做:objinstanceofMyObject它返回false。这让我感到困惑,因为我认为这会返回true。我在这里做错了什么?这是一个fiddle测试这个。我以为我掌握了JavaScript的基础知识,但也许不是。但是,我找到了sources这与我的发现相矛盾。

javascript - 通过 "this"和 "prototype"分配函数有什么区别?

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Useof'prototype'vs.'this'inJavascript?我对这两种向函数添加方法感到困惑。让我用一个例子来解释。varfoo=function(){this.bar=function(){alert('Iamamethod')}}foo.prototype.baz=function(){alert('Iamanothermethod')}varcar=newfoo();此时我们可以对汽车使用baz和bar方法。好吧,但是它们之间有什么区别。向函数的原型(prototype)或其构造函数添加

javascript - typescript : Unexpected token; 'constructor, function, accessor or variable'

我用类型脚本编写了以下类。当我编译它时,它会出错说"src\main\MqttClientWrapper.ts(24,2):错误TS1068:意外的token。一个构造或者,需要方法、访问器或属性。”。下面是我的代码。varmqtt:any=require('mqtt');exportinterfaceIWillMessage{topic:string;payload:string;qos:number;retain:string;}exportinterfaceIMessageReceivedCallBack{onMessageReceived(message:string);}ex

javascript - 有没有办法在父类中获取子类的名称?

我正在尝试在其父类(superclass)(A)中打印出类B或C的名称。有没有办法从上下文中以某种方式推断出这一点?我是否必须将名称作为参数传递到super中,或者有更好的方法吗?classA{constructor(){console.log(klass_name)//klass_nameissomecodetogetthenameofclassB,C}}classBextendsA{constructor(){super();}}classcextendsA{super();} 最佳答案 是的,您可以通过两种方式在您显示的位置访

javascript - 为什么不应该向 JavaScript 构造函数添加功能,而是通过原型(prototype)添加功能?

我在看AddyOsmani关于构造函数模式的章节:http://addyosmani.com/resources/essentialjsdesignpatterns/book/#constructorpatternjavascript我遇到了以下情况:functionCar(model,year,miles){this.model=model;this.year=year;this.miles=miles;this.toString=function(){returnthis.model+"hasdone"+this.miles+"miles";};}//Usage://Wecancr

javascript - 检查对象中的 "constructor"键的奇怪 javascript 行为

我实际上不确定我是否只是偶然发现了javascript中不需要的行为,或者这是否是某种有意为之的行为。以下代码生成一个true语句:vartest={"test":1}document.write("constructor"intest);http://jsfiddle.net/xyatxm2g/2/如果我将其更改为以下代码,它会按预期返回false:vartest={"test":1}document.write(test.hasOwnProperty("constructor"));http://jsfiddle.net/fg06ovvc/2/ 最佳答案

javascript - ES6 类中的 constr.apply(this, args)

一段时间以来,我一直在使用以下函数来创建未知类的实例:Kernel.prototype._construct=function(constr,args){functionF(){constr.apply(this,args);//EXCEPTION!}F.prototype=constr.prototype;returnnewF();};如果我使用原型(prototype),一切正常:functionPerson(name,surname){this.name=name;this.surname=surname;}varperson=Kernel._construct(Person,[

javascript - 为什么在 JavaScript 中函数既是构造函数又是对象?

我最近对此进行了大量研究,但尚未得到真正可靠的答案。我在某处读到,当JavaScript引擎遇到函数语句时会创建一个新的Function()对象,这让我相信它可能是一个对象的子对象(因此成为一个对象)。所以我给DouglasCrockford发了邮件,他的回答是:Notexactly,becauseafunctionstatementdoesnotcallthecompiler.Butitproducesasimilarresult.此外,据我所知,您不能在函数构造函数上调用成员,除非它已被实例化为一个新对象。所以这是行不通的:functionmyFunction(){this.myP

javascript - Firefox 和 chrome constructor.prototype 之间的行为差​​异?

经过多次试验,我发现__proto__或Object.getPrototypeOf()方法是遍历DOM对象中原型(prototype)链的正确方法。使用一系列constructor.prototype实际上并没有在两个浏览器中遍历原型(prototype)链。(虽然这是ECMA标准中定义的方式,constructor的prototype属性是你的原型(prototype)对象)。欢迎任何建议或评论...p1=document.getElementById("test");//divelement//PrototypeObjectofp1p2=element.constructor.pr