草庐IT

继承关系

全部标签

javascript - 没有原型(prototype)的原型(prototype)继承?

我想我了解JS中的原型(prototype)继承,但在编写代码来展示我的特定想法时遇到了困难。考虑这个极其简单的场景,其中Manager对象派生自Employee对象:functionEmployee(){this.name="Axel";this.dept="R&D";}functionManager(){Employee.call(this);this.reports=["Report1","Report2","Report3"];}console.log(newManager());输出是:Manager{name:"Axel",dept:"R&D",reports:Array[

javascript - 防止 JavaScript 闭包继承作用域

我正在寻找一种奇特的方法来防止闭包继承周围的范围。例如:letfoo=function(t){letx='y';t.bar=function(){console.log(x);//=>'y'});};我只知道两种方法来阻止共享范围:(1)使用影子变量:letfoo=function(t){letx='y';t.bar=function(x){console.log(x);//=>'?'});};(2)把函数体放在别处:letfoo=function(t){letx='y';t.bar=createBar();};我的问题是-有谁知道防止闭包继承JS范围的第三种方法吗?花哨的东西很好。我

Javascript,扩展ES6类setter会继承getter

在Javascript中,具有以下说明代码:classBase{constructor(){this._val=1}getval(){returnthis._val}}classXtndextendsBase{setval(v){this._val=v}}letx=newXtnd();x.val=5;console.log(x.val);//prints'undefined'实例x不会从Base类继承getval()...。实际上,Javascript在存在setter的情况下将缺少getter视为未定义。我遇到的情况是,我有很多类都具有完全相同的一组获取方法,但设置方法各不相同。目前

javascript - 如何使用 JavaScript 对象文字进行继承?

您好,我在使用对象字面量语法声明对象原型(prototype)时遇到继承问题。我做了两个Fiddles来帮你帮我。Fiddle1,ThisoneworksFiddle2,Thisonedoesn'twork这是我的基类,在我的应用程序中几乎所有的对象都是这样定义的:Base=function(param){this.init(param);}Base.prototype={init:function(param){this.param=param;},calc:function(){varresult=this.param*10;document.write("Resultfromca

javascript - MouseOver/MouseOut 事件监听器继承到子节点?

编辑:解决方案感谢Gaby寻求解决方案的帮助!没有完全按照我想要的方式工作,找到了一个根据答案修改的更好的解决方案。我所做的只是在两个元素(目标和相关目标)不共享父元素时执行鼠标悬停/鼠标移出功能。只是稍微修改了Gaby的示例,一切正常。只要你的弹出窗口与生成它的任何东西都在同一个div元素内(即使它在主要内容之外,你可以附加它并显示溢出)并且你不会在到达它的途中在非共享元素之间穿梭,它会活着。divContents.addEventListener('mouseover',mouseEnter(showPopup,divContents));divContents.addEventL

javascript - three.js继承模式

我想知道为什么three.js的代码结构是这样的:THREE.Camera=function(){THREE.Object3D.call(this);//addmoreCameraspecificpropertiesandmethods}THREE.Camera.prototype=newTHREE.Object3D();THREE.Camera.prototype.constructor=THREE.Camera;THREE.Camera.prototype.//addmorecameraspecificmethods...我想知道为什么他们在当前构造函数中调用基础构造函数并且还为原

javascript - 在 Angular 2 中的非父/子关系组件之间传递值

根据我的理解,在Angular2中,如果你想在不相关的组件之间传递值(即,不共享路由的组件,因此不共享父子关系),你可以通过共享服务。这就是我在Angular2应用程序中设置的内容。我正在检查url中是否存在特定系列的字符,如果存在则返回true。isRoomRoute(routeUrl){if((routeUrl.includes('staff')||routeUrl.includes('contractors'))){console.log('Thisurl:'+routeUrl+'isaroomRoute');returntrue;}else{console.log('Thisu

javascript - Shadow Dom继承父页面CSS [Chrome]

这个问题在这里已经有了答案:LightDOMstyleleakingintoShadowDOM(1个回答)关闭2年前。我读过的所有内容都表明ShadowDom对于其父页面CSS来说应该是“安全的”。IE。如果我将所有div样式设置为紫色字体:div{color:purple}我的ShadowDom中的div应该具有浏览器默认颜色。我正在编写一个chrome扩展程序,可以将html注入(inject)任何给定页面。除非此html受ShadowDom或Iframe保护,否则它将继承页面的所有CSS。解决这个问题的建议在这个question,是使用ShadowDom。所以我实现了一个解决方案

javascript - javascript的继承

也许这个问题很简单,但我现在无法理解。String.prototype.self=function(){returnthis;}vars="s";alert("s".self()=="s".self())//false;alert(s.self()==s.self())//false;如果你知道原因,请告诉我为什么结果是“假”。 最佳答案 那是因为当从原始值(例如"s")访问属性时,propertyaccesors在ToObject内部强制它,并且比较失败,因为它检查两个不同的对象引用。例如:String.prototype.tes

javascript - 只是好奇如何继承 String 对象。 (原型(prototype))

我知道这是不受欢迎的,我只是在探索这个想法,就我的生活而言,似乎无法按照我想要的方式完成这项工作。这个例子应该解释所有:String.prototype.MyNS=function(){}String.prototype.MyNS.fooify=function(){returnthis+'foo!';}vartheString='Kung';alert(theString.MyNS.fooify());当然,这只是将函数定义附加到“foo”……添加this()是行不通的。我知道我在那里失去了背景,但无法弄清楚如何让原件开火并给我我想要的东西。 最佳答案