10分钟了解jQuery基础框架
沉沙 2018-05-28 来源 : 阅读 1015 评论 0

摘要:本文讲解了jQuery基础框架的原型模式结构、返回选择器、访问原型方法和自执行匿名函数,希望阅读本篇文章以后大家有所收获,加深大家对jQuery的理解。

一、原型模式结构

// 定义一个jQuery构造函数2 var jQuery = function() {3 4 };5 6 // 扩展jQuery原型 7 jQuery.prototype = {8 9 };

上面是一个原型模式结构,一个jQuery构造函数和jQuery实例化对象的的原型对象,我们一般是这样使用的:

 var jq = new jQuery(); //变量jq通过new关键字实例化jQuery构造函数后就可以使用原型对象中的方法,但是jQuery并不是这么使用的


二、返回选择器实例 

 var jQuery = function() { 
      
     // 返回选择器实例 
     return new jQuery.prototype.init(); 
 }; 
 jQuery.prototype = { 
  
     // 选择器构造函数 
     init: function() {
 
     }
 };

虽然jQuery不是通过new关键字实例化对象,但是执行jQuery函数仍然得到的是一个通过new关键字实例化init选择器的对象,如:

1 var navCollections = jQuery('.nav');  //变量navCollections保存的是class名为nav的DOM对象集合.


三、访问原型方法 

 var jQuery = function() { 
      
     // 返回选择器实例 
     return new jQuery.prototype.init(); 
 }; 
 jQuery.prototype = { 
  
     // 选择器构造函数 
     init: function() {
 
     },
 
     // 原型方法
     toArray: function() {
 
     },
     get: function() {
 
     }    
 };
 
 // 共享原型
 jQuery.prototype.init.prototype = jQuery.prototype;

 

我们一般习惯称jQuery函数中返回的选择器实例对象为jQuery对象,如我们可以这样使用:

 jQuery('.nav').toArray(); // 将结果集转换为数组

 

为什么可以使用toArray方法呢? 即如何让jQuery对象访问jQuery.prototype对象中的方法?只需将实例化选择器对象的原型对象共享jQuery.prototype对象,上面体现代码为:

jQuery.prototype.init.prototype = jQuery.prototype; // 共享原型


四、自执行匿名函数

 (function(window, undefined) { 
  
     var jQuery = function() { 
          
         // 返回选择器实例 
         return new jQuery.prototype.init(); 
     }; 
     jQuery.prototype = { 
 
         // 选择器构造函数
         init: function() {
         },
 
         //原型方法
         toArray: function() {
 
         },
         get: function() {
 
         }    
     };
     jQuery.prototype.init.prototype = jQuery.prototype;
 
     // 局部变量和函数在匿名函数执行完后撤销
     var a, b, c;
     function fn() {
 
     }
 
     // 使jQuery成为全局变量
     window.jQuery = window.$ = jQuery;
 
 })(window);

自执行匿名函数中声明的局部变量和函数在匿名函数执行完毕后撤销,释放内存,对外只保留jQuery全局变量接口。

 

本文由职坐标整理并发布,了解更多内容,请关注职坐标WEB前端jQuery频道!


本文由 @沉沙 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程