草庐IT

Java泛型和数组构造

全部标签

javascript - 在 TypeScript 中动态返回一个类构造函数

我正在尝试在TypeScript中构建一种机制,以根据表示类名称的字符串参数返回类的新实例。基本上,我正在尝试创建一个工厂,只是我不太清楚如何在TypeScript中执行此操作。在纯JS中,我可以通过将所有类构造函数存储在一个键/值对象中并调用newClassDictionary[className]();来解决这个问题——这不是最可靠的解决方案,但它在这种情况下工作。我似乎无法获得类型和转换的正确组合来在TypeScript中完成此操作。有没有更好的办法?我在TypeScript中找不到工厂模式的任何示例,所以现在我只有一点switch语句,它丑陋且不灵活。

javascript - 按数据属性、字母顺序和数字顺序对列表项进行排序

我想从A-Z然后0-9对这个列表进行排序。y1aecw09g$(".columnsli").sort(sort_li).appendTo('.columns');functionsort_li(a,b){return($(b).data('char'))看了类似的问题,这是我想出的,但它只适用于数字或字母(不是两者)。https://jsfiddle.net/qLta1ky6/ 最佳答案 数字的ASCII码比字母小,所以比较的时候直接加权重就可以了:$(".columnsli").sort(sort_li).appendTo('.c

javascript - String 和 Array 泛型方法将在未来被弃用

在下面的链接(MDN站点)上它说“字符串泛型是非标准的,已弃用并且将来可能会被删除。请注意,如果不使用下面提供的填充程序,您不能跨浏览器依赖它们。“他们所指的方法是否是他们在该声明下方提供的垫片中列出的方法?这是我见过的唯一提到短语“字符串泛型”的地方,所以让我很困惑。对于数组泛型也有同样的问题,因为该站点也提到了类似的情况。https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String#String_generic_methodshttps://developer.mozi

javascript - 构造函数中的事件处理程序与构造函数外的事件处理程序的行为不同

我有一个对象的两个实例,它们扩展了EventEmitter并监听名为finish的事件。如果我在构造函数之外设置事件处理程序,一切都会按预期进行。每个实例都会听到它触发的finish的出现。但是,如果我在构造函数中设置事件处理程序,则只有第二个创建的实例会听到事件并对事件使用react,或者看起来是这样。代码如下:varutil=require('util');varEventEmitter=require('events').EventEmitter;varfs=require('fs');varNEXT_ID=0;varMyEmitter=function(){EventEmitt

javascript - 如何在 typescript 中初始化构造函数中的常量字段?

我不知道这是否有值(value)。我只是好奇这是否可能?问题:如果可能,语法是什么在typescript的构造函数中初始化一个const字段?`exportclassGulpfile{privatedist:string;privatesrc:string;constructor(){constthis.dist='./dist/';this.src='./src'}} 最佳答案 你不能有常量类成员。主要是因为类成员总是通过this关键字引用,并且该引用始终可以更改。ES6也不支持。 关

javascript - 我什么时候需要使用 super(props) 将 prop 传递给 React 组件的构造函数?

这个问题在这里已经有了答案:What'sthedifferencebetween"super()"and"super(props)"inReactwhenusinges6classes?(10个答案)关闭6年前。很多时候我们在构造函数中发送props但我们从来没有在构造函数中的任何地方使用this.props那么为什么需要传递它以及何时需要这样做。classAppextendsReact.Component{constructor(props){super(props);//Whendoweneedtosendpropstotheconstructorthis.state={data:

javascript - 如何在 ES6 中调用类的父类的父类的构造函数?

我正在使用ES6类,我的类(A)扩展了类B,类B扩展了类C。A如何扩展方法,然后调用C的该方法版本。classC{constructor(){console.log('classc');}}classBextendsC{constructor(){super()console.log('no,Idon'twantthisconstructor.');}}classAextendsB{constructor(){//WhatshouldIbedoinghere?IwanttocallC'sconstructor.super.super();}}编辑:谢谢大家,我将停止尝试做这种愚蠢的事情

javascript - 如何导出 ES6 类并在另一个模块中构造它的实例?

使用Node.js版本7.7.2,我想从这样的模块中定义和导出ES6类://Foo.jsclassFoo{construct(){this.bar='bar';}}module.exports=Foo;然后将该类导入另一个模块并构造该类的实例,如下所示://Bar.jsrequire('./foo');varfoo=newFoo();varfooBar=foo.bar;但是,这种语法不起作用。我尝试做的事情是否可行?如果可行,实现此目标的正确语法是什么?谢谢。 最佳答案 您必须为此使用常规Node模块语法。您的示例代码中有一些错误。

javascript - IE 11 找不到运行 Applet 的 Java 插件

我有使用JavaApplets构建的应用程序,它适用于带有IE9的Windows7。现在我正在尝试将它移动到另一个环境。有InternetExplorer11。要运行小程序,我使用OracleDeploymentToolkitScript最新版本取自https://www.java.com/js/deployJava.txt.但是脚本没有检测到Java插件。它只会重定向到页面java.com(建议下载最新的JRE)。但是我的浏览器安装了Java插件(这里是JRE1.7.80):还有两个SSVHelpers-也许是它们导致了问题?Java8(u144)导致同样的问题。问题:如何检测IE1

javascript - 通过 this 在 typescript 中从派生类型调用构造函数

在我的typescript中,我试图通过基类中的方法创建/克隆子对象。这是我的(简化的)设置。abstractclassBaseClass{protectedprops:TCompositionProps;protectedcloneProps():TCompositionProps{return$.extend(true,{},this.props);}//canbeoverwritenbychildsconstructor(props:TCompositionProps){this.props=props;}clone(){constprops=this.cloneProps();