草庐IT

javascript - 在保留对象引用和继承的同时组织原型(prototype) javascript

我使用JavaScript原型(prototype)和继承构建了一个大型应用程序。但是我很难组织我的代码。例如,我有一个类轮播,它有很多这样的功能:Carousel.prototype.next=function(){...}Carousel.prototype.prev=function(){..}Carousel.prototype.bindControls=function(){..}我想这样组织我的代码:Carousel.prototype.controls={next:function(){...},prev:function(){...},bindControls:func

javascript - 原型(prototype)继承中的 call() 需要什么

我在破译JavaScript中的原型(prototype)继承时遇到了一些麻烦,并想在这里发布它。考虑这个简单的例子:functionEmployee(){this.name="Rob";this.dept="R&D";}functionManager(){//Employee.call(this);this.reports=["Report1","Report2","Report3"];}Manager.prototype=Object.create(Employee.prototype);Employee.prototype.type="human";m=newManager();

javascript - __proto__ 和 JavaScript 中的继承

我已经研究了几天JavaScript继承,虽然我已经取得了很大的进步,但有些事情我还不太明白。例如,我发现这种行为非常令人困惑:varEmployee=functionEmployee(){this.company='xyz';};varManager=functionManager(){this.wage='high';};varm=newManager();m;//{"wage":"high",__proto__:Manager}--noproblemssofar.Manager.prototype=newEmployee();varn=newManager;m.company;/

JavaScript 继承 : When where's my derived members?

看看下面的代码:functionPrimate(){this.prototype=Object;this.prototype.hairy=true;}functionHuman(){this.prototype=Primate;}newHuman();当您检查newHuman()时,没有hairy成员。我希望会有一个。有没有其他方法可以让我从Primate继承?涉及Object.create()的内容(ECMAScript5适合在我的场景中使用)? 最佳答案 在编写代码时,使用newHuman()创建的对象将具有一个名为protot

javascript - 原型(prototype)继承的差异,Firefox 与 Chrome

对于下面的代码:functionMammal(){this.hair=true;this.backbone=true;returnthis;}functionCanine(){this.sound='woof';returnthis;}Canine.prototype=newMammal();functionDog(name){this.tail=true;this.name=name;returnthis;}Dog.prototype=newCanine();varaspen=newDog('Aspen');varaspenProto=aspen.__proto__Firebug(F

javascript - Webpack 在使用继承缩小/丑化 ES6 代码时删除了类名

Webpack在使用继承缩小/丑化ES6代码时删除了类名:有MVCE我们尝试缩小/丑化的代码:子类:constParentClass=require('parent');classChildextendsParentClass{constructor(){super();}}module.exports=Child;index.js调用Child类:constChild=require('./classes_so/child');letchild=newChild();console.log(child.constructor.name);node_modules中的ModulePar

javascript - 为什么 console.log() 不显示从 Object.create 继承的属性?

我在尝试利用基础对象上的Object.defineProperty()时遇到了问题。我想使用Object.create()从该对象继承属性,然后在派生对象(可能从那里继承)中定义更多属性。我应该指出,我的目标是node.js。这是一个例子:varBase={};Object.defineProperty(Base,'prop1',{enumerable:true,get:function(){return'prop1value';}});Object.defineProperty(Base,'prop2',{enumerable:true,value:'prop2value'});Ob

javascript - Javascript 中的继承

我正在研究Javascript中的继承概念,我正在看的教程使用了这段代码://definetheStudentclassfunctionStudent(){//CalltheparentconstructorPerson.call(this);}//inheritPersonStudent.prototype=newPerson();//correcttheconstructorpointerbecauseitpointstoPersonStudent.prototype.constructor=Student;我的问题是,为什么有必要同时调用父构造函数Person.call(this

javascript - 从 native 对象继承

我似乎遗漏了一些关于Javascript中使用native对象的构造函数链继承的信息。例如:functionErrorChild(message){Error.call(this,message);}ErrorChild.prototype=Object.create(Error.prototype);varmyerror=newErrorChild("Help!");为什么myerror.message在这些语句之后被定义为""?我希望Error构造函数将其定义为“帮助!”(并覆盖Error.prototype.message的默认值),就像我在做的那样:varmyerror=new

javascript - 覆盖继承的原型(prototype)方法并在新方法中调用原始方法

在下面的代码中,如何访问B.prototype.log中的A.prototype.log?functionA(){}A.prototype.log=function(){console.log("A");};functionB(){}B.prototype=Object.create(A.prototype);B.prototype.constructor=B;B.prototype.log=function(){//callA.prototype.loghereconsole.log("B");};varb=newB();b.log();我知道我可以只写A.prototype.log