使用隐藏的new来创建对象
jQuery中发现的,jQuery.Event类。估计作者是为了减少代码量。定义一个类,但不用new关键字去创建该类对象,而使用方法调用()方式去创建该对象。
很多时候我们是这样写类,然后使用new创建对象的。
1 2 3 4 5 6 7 8 9 | function Person(name,age){ this .name=name; this .age=age; } Person.prototype={ setName : function (n){ this .name=n;}, getName : function (){ return this .name;} } var p = new Person( 'jack' ,25); |
改成这样的
1 2 3 4 5 6 7 8 9 10 11 12 13 | function Person(name,age){ //条件改为(this==window)或(this==self)或(this.constructor!=Object) if (! this .setName){ return new Person(name,age); } this .name=name; this .age=age; } Person.prototype={ setName : function (n){ this .name=n;}, getName : function (){ return this .name;} } var p = Person( 'jack' ,25); |
注意该类较最上面的写类方式中多了以下
1 2 3 | if (! this .setName){ return new Person(name,age); } |
好,创建类的实例(对象)方式也变成了如下
1 | var p = Person( 'jack' ,25); |
这种创建方式(函数调用)较上面的少了“new_”,new和空格,实际上是在类内部new了。而这样方式每次创建对象可以减少4个byte。
如果把类内部的if判断条件换成非prototype上的属性,如this.name。程序会提示出错:too much recursion
1 2 3 4 5 6 7 8 9 10 11 12 | function Person(name,age){ if (! this .name){ return new Person(name,age); } this .name=name; this .age=age; } Person.prototype={ setName : function (n){ this .name=n;}, getName : function (){ return this .name;} } var p = Person( 'jack' ,25); |
分类:
jQuery
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端