草庐IT

Python装饰器和继承

全部标签

javascript - TypeScript类继承构造函数混淆

我正在学习EloquentJavascript这本书,但在章节结尾的练习中遇到了一些障碍。我很早就决定,我将主要使用TypeScript来解决vanillaJS之上的这些练习,只是为了让自己接触TS提供给我的额外功能。完整的练习可以在这里找到:http://eloquentjavascript.net/06_object.html#h_nLNNevzcF7在我看来,我应该基本上扩展作者在本章中定义的预先存在的类,我已尽最大努力用TypeScript重新编写以利用类://fromtextbook.functionrepeat(string:string,times:number):str

javascript - 有条件地阻止方法执行的 JS TS 装饰器

我想编写一个方法装饰器,有条件地阻止执行该方法或用其他过程替换该方法。特别是我希望根据在客户端或服务器上调用时的不同行为:functionserverMethod(target){if(Meteor.isClient){//callservermethodtodeleteauser//preventexecutionofdecoratedmethod}}classUser{@serverMethoddelete(){UserCollection.delete(this.id)}} 最佳答案 1。概念概述ES2016方法装饰器是具有3

javascript - babel 装饰器和 TypeScript 的一样吗?

我经常使用TypeScript编写代码,但很少使用babel,我知道TypeScript如何在装饰器上工作,而babel也支持装饰器,它们的行为是否相同? 最佳答案 是的,它们是相同的,从某种意义上说它们产生相同的行为,但它们有不同的实现。两者都遵循ECMAScript规范并尽早为我们带来功能。您可以预期它们两者上的内容将来可能会受到节点或浏览器的支持。代码:functionf(){console.log("f():evaluated");returnfunction(target,propertyKey,descriptor){c

javascript - 使用 Douglas Crockford 的函数继承在 Javascript 中调用基方法

基本上我如何使用下面的这种模式调用基本方法?varGS={};GS.baseClass=function(somedata){varthat={};that.data=somedata;//Baseclassmethodthat.someMethod=function(somedata){alert(somedata);};returnthat;};GS.derivedClass=function(somedata){varthat=GS.baseClass(somedata);//Overwritingbasemethodthat.someMethod=function(someda

javascript - JavaScript 原型(prototype)链中的方法继承

"在javascript中,每个对象都有一个到创建它的对象的secret链接,形成一个链。当一个对象被要求提供一个它没有的属性时,它的父对象被询问......不断在链中向上,直到找到该属性或直到到达根对象。"总而言之,我一直认为上面的话是真的,所以我做了一些测试来验证它,我打算像下面这样定义对象的关系。请查看。代码应该如下所示。//Shape-superclassfunctionShape(){this.x=0;this.y=0;};Shape.prototype.move=function(x,y){this.x+=x;this.y+=y;alert('Shapemove');};/

javascript - React 和 ES6 继承

注意:这篇文章是在React不支持ES6(v12)时发布的。我有一个ES6类:classBaseClass{getInitialState(){return{message:'Hello!'};}render(){return({this.state.message})}}我可以使用这个表达式在ES6中导出(来源:reactES6browserify)exportdefaultReact.createClass(BaseClass.prototype)这很好用。现在我想使用ES6继承来扩展我的BaseClass类:classExtendedClassextendsBaseClass{g

javascript - 是否可以从 JavaScript 中的 ECMAScript 6 类继承旧式类?

在Node.js4.2.1上运行以下代码时:'usestrict';varutil=require('util');classMyClass{constructor(name){this.name=name;}}functionMyDerived(){MyClass.call(this,'MyDerived');}util.inherits(MyDerived,MyClass);vard=newMyDerived();我收到以下错误:constructor(name){^TypeError:Classconstructorscannotbeinvokedwithout'new'我想知道

JavaScript 装饰器模式。错误 : Maximum call stack size exceeded

这是装饰器模式的一个工作示例:classDummy{run(){console.log('run');}}functionget(){letinstance=newDummy();instance.run=((func)=>{returnfunction(){func();console.log('decoratorrun');}})(instance.run);returninstance;}letobj=get();obj.run();但是,如果我们将get函数更改为:functionget(){letinstance=newDummy();instance.run=functio

javascript - DOM 背景颜色传播闪烁继承 Google Chrome 中的初始背景颜色,使用主题切换来重载主体背景颜色

我目前正在为我的网站开发一个主题切换器,它使用Javascript/jQuery来使用由按钮切换的lightmode()/darkmode()函数来操纵Body.bg颜色。我想要做的是在主体背景颜色与淡入淡出之间创建无缝过渡。我已经制作并创建了它,但问题是当主题读取存储类型时,它会在Chrome和ChromeCanary中快速闪烁,但在Safari和Catalina的SafariTechPreview中它可以无缝工作。但是,当用户切换到白色然后单击导航链接时,我一直遇到一个问题,这会导致暗模式主题黑色闪烁。我的网站开始时启用了暗模式,bodybg=#0a0a0a,但是当它切换到白色并更

javascript - JavaScript 中的继承导致 Uncaught TypeError

可能是我在这里遗漏了什么。请耐心等待,因为我是JavaScript中OOP的新手。但我需要找到解决我的问题的方法。我有这个代码。varparent=function(){}parent.prototype.someFunc=function(){return"astring";}现在我正在尝试使用如下代码继承父对象,varchild=function(){parent.call(this);}child.prototype=newparent();当我这样做时,它会起作用。varobj=newchild();obj.someFunc();但我想在child里面有someFunc(),如