博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
jQuery的无new构建
阅读量:4317 次
发布时间:2019-06-06

本文共 771 字,大约阅读时间需要 2 分钟。

正常面向对象的写法:

  var cJquery = function(){

    //构造函数体

  };

  cJquery.prototype = {

    name : function(alert("chenliang");)

    age : function(alert(27);)

  }

  var c = new cJquery();

  c.name();

 

使用jQuery时,并不会使用new来创建jQuery对象,而是类似一个工厂,不断的根据不同的需求产出不同的jQuery对象。

例如:

  var cJquery = function(){

    new cJquery();

  }

  因为new的其中一步就是执行构造函数体,所以,这种写法会造成无限循环

 

因此,jQuery采用了返回一个假jQuery对象来代替jQuery对象的方法(个人理解,不知道对不对)

  var jQuery = function(){

    return new jQuery.prototype.init();

  }

  jQuery.prototype = {

    init : function(){

      return this;

    },

    name : function(){alert("chenliang");}

  }

  但这种做法的后果是,jQuery返回的假jQuery对象(init对象),无法访问jQuery的原型对象上的方法。

  因此jQuery做了最后一步处理:

  jQuery.protype.init.protype = jQuery.protype;

转载于:https://www.cnblogs.com/charling/p/3395608.html

你可能感兴趣的文章
java开发操作系统内核:由实模式进入保护模式之32位寻址
查看>>
第五讲:单例模式
查看>>
Python编程语言的起源
查看>>
Azure ARMTemplate模板,VM扩展命令
查看>>
使用Masstransit开发基于消息传递的分布式应用
查看>>
[CF808A] Lucky Year(规律)
查看>>
关于推送遇到的一些问题
查看>>
寒假作业3 抓老鼠啊~亏了还是赚了?
查看>>
Orcal Job创建实例
查看>>
Django
查看>>
批量Excel数据导入Oracle数据库(引用 自 wuhuacong(伍华聪)的专栏)
查看>>
处理移动障碍
查看>>
优化VR体验的7个建议
查看>>
2015年创业中遇到的技术问题:21-30
查看>>
《社交红利》读书总结--如何从微信微博QQ空间等社交网络带走海量用户、流量与收入...
查看>>
JDK工具(一)–Java编译器javac
查看>>
深入.NET框架与面向对象的回顾
查看>>
merge http://www.cplusplus.com/reference/algorithm/merge/
查看>>
Python-DB接口规范
查看>>
改变label中的某字体颜色
查看>>