声明:虽然是基本概念但也是笔者经过一番学习才总结的这些文章,所以他不包括Jquery优缺点、特点、语法的介绍。

概念一:jQuery对像与DOM对象

  DOM(Document Object Model, 文档对象模型)他可以表示成数据结构的树

<html>
<head></head>
<body>
<h1></h
</body>
</html>

就像上面表示html、head、body、h1都是DOM元素节点并且具有父、兄关系,可以通过JS中的方法获得这些方法

var domOjb = document.getElementBy("id");

  jQuery对象就是通过jQuery包装DOM对象后产生的对象

  jQuery对象是jQuery独有的,如果一个对象是jQuery对象,那么就可以使用jQuery里的方法

$("#foo").html()//获得id=foo的元素内的HTML代杩

  等价于:

document.getElementById("foo").innerHTML;

两者获取的对象是不同的,所以他们的方法也不能相互调用

  jQuery对象与DOM对象的相互转换

var #cr = $("#cr");
var ce = $cr[0];

var $cr = $("#cr");
var cr = $cr.get(0);
var cr = document.getElementById("cr");
var $cr = $(cr);

概念二:闭包在插件中的应用

  关于闭包这个概念是困惑我最久的东西,$、jQuery、()、{}这些字符串的一开始的写法是让人很是费解,希望这次我能够说青楚,也能大家少走弯路。

闭包在插件开发过程是用的最多的,说白了他就有点类似java里面的内类。

  在这里可以先补上JS闭包的概念:http://www.cnblogs.com/mzwr1982/archive/2012/05/20/2509295.html

在理解闭包以前.最好能先理解一下作用域链的含义,简单来说,作用域链就是函数在定义的时候创建的,用于寻找使用到的变量的值的一个索引,而他内 部的规则是,把函数自身的本地变量放在最前面,把自身的父级函数中的变量放在其次,把再高一级函数中的变量放在更后面,以此类推直至全局对象为止.当函数 中需要查询一个变量的值的时候,js解释器会去作用域链去查找,从最前面的本地变量中先找,如果没有找到对应的变量,则到下一级的链上找,一旦找到了变 量,则不再继续.如果找到最后也没找到需要的变量,则解释器返回undefined.

  了解了作用域链,我们再来看看js的内存回收机制,一般来说,一个函数在执行开始的时候,会给其中定义的变量划分内存空间保存,以备后面的语句 所用,等到函数执行完毕返回了,这些变量就被认为是无用的了.对应的内存空间也就被回收了.下次再执行此函数的时候,所有的变量又回到最初的状态,重新赋 值使用.但是如果这个函数内部又嵌套了另一个函数,而这个函数是有可能在外部被调用到的.并且这个内部函数又使用了外部函数的某些变量的话.这种内存回收 机制就会出现问题.如果在外部函数返回后,又直接调用了内部函数,那么内部函数就无法读取到他所需要的外部函数中变量的值了.所以js解释器在遇到函数定 义的时候,会自动把函数和他可能使用的变量(包括本地变量和父级和祖先级函数的变量(自由变量))一起保存起来.也就是构建一个闭包,这些变量将不会被内 存回收器所回收,只有当内部的函数不可能被调用以后(例如被删除了,或者没有了指针),才会销毁这个闭包,而没有任何一个闭包引用的变量才会被下一次内存 回收启动时所回收.

也就是说,有了闭包,嵌套的函数结构才可以运作,这也是符合我们的预期的.然后,闭包还有一些特性,却往往让程序员觉得很难理解.

看看下面一段代码.

var result=[];
function foo(){
var i= 0;
for (;i<;i=i+1){
result[i]=function(){
alert(i)
}
}
};
foo();
result[0](); // 3
result[1](); // 3
result[2](); // 3

这段代码中,程序员希望foo函数中的变量i被内部循环的函数使用,并且能分别获得他们的索引,而实际上,只能获得该变量最后保留的值,也就是说.闭包中所记录的自由变量,只是对这个变量的一个引用,而非变量的值,当这个变量被改变了,闭包里获取到的变量值,也会被改变.

解决的方法之一,是让内部函数在循环创建的时候立即执行,并且捕捉当前的索引值,然后记录在自己的一个本地变量里.然后利用返回函数的方法,重写内部函数,让下一次调用的时候,返回本地变量的值,改进后的代码:

var result=[];
function foo(){
var i= 0;
for (;i<;i=i+1){
result[i]=(function(j){
return function(){
alert(j);
};
})(i);
}
};
foo();
result[0](); // 0
result[1](); // 1
result[2](); // 2

保护 i变量的访问,并且一直保存i在内存中,可以一直增加-------这是闭包的主要作法

function a(){
var i=0;
function b(){
alert(++i);
}
return b;
} var c = a();
c(); //1
c(); //2

内部函数可以访问它们所在的外部函数中专声明的所有局部变量、参数和声明的其它内部函数,当其中一个这样的内部函数在包含它们的外部函数之外被调用时,就会形成闭包

利用内部函数定义的临时变量不会影响全局空间,于是就有下面这种写法:

(function(){})();
定义了一个匿名函数function(){}然后用()括起来,接着用()来执行这个函数这就是典型的()()写法

如果要传参数可以是:

(function($){
$("div p").click("这里用$可不会和其它插件冲突哦");
})(jQuery);
相当于:
function temp($){
$("div p").click("这里用$可不会和其它插件冲突哦");
}
temp(jQuery)此时传入jQuery对角作为实际参数
因为我们实际传入的参数是jQuery,所以形参$就是作为jQuery对象的缩写

来看一段jQuery代码:

((function($){
var foo;
var bar = function(){
/*在匿名函数内部的函数都可以访问foo,即使是在匿名函数的外部调用bar()的时候,
也可以在 bar()的内部访问到foo,但是匿名函数的外部直接访问foo是做不到的*/
}
/*下面的语名让匿名函数内部的函数bar()逃逸到全局可访问的范围内
这样就可以在匿名函数的外部通过调用jQuery.BAR()来访问内部定
义的函数bar(),并且内部函数bar()也能访问匿名函数内的变量foo*/
$.BAR = bar;
})(jQuery)

 概念三:解决jQuery和其它库的冲突

  1、jQuery库在其它库之后导入

    在其它库和jQeury库都被加载完毕后,可以在任何时候调用jQuery.noConflict()函数来将变量$的控制权移交给其它javaScript库。

<p id="pp">隐藏元素</p>
<p>绑定单击事件</p>
<!--引入prototype-->
<script src="lib/prototype.js" type="text/javascript"></script>
<!--引入jquery-->
<script src="../../scripts/jquery.js" type="text/javascript"></script>
<script>
jQuery.noConflict(); //将变量$的控制权移交给prototype.js
jQuery.(function){ //使用jquery
jQuery("p").click(function(){
alert(jQuery(this).text());
});
})
$("pp").style.display="none" //使用prototype.js隐藏元素
</script>

  此时,Jquery()函数作为jQuery对像的制造工厂,还有加外一个作法

var $j=jquery.noConflict();  //自定义一个快捷方式
$j(function(){
$j("p").click(function(){ //使用jquery,利用自定义快捷方式----$j
alert($j(this).text());
})
})
$("pp").style.display="none"; //使用prototype.js隐藏元素

  如果不想自定义这这些名称,还想使用$而不管其它库的$()方法,同时又不想与其他库相冲突,那么可以使用以下两种解决方法

  一:

jQuery.noConflict();      //将变量$的控制权移交给prototype.js
jQuery(function($){ //使用jQuery设定页面加载时执行的函数
$("p").click(function(){ //在函数内部继续使用$()方法。
alert($(this).text());
})
})
$("pp").style.display="none" //使用prototype

  二:

jQuery.noConflict();      //将变量$的控制权让渡给prototype.js
(function(($){ //定义匿名函数并设置形参$
$(function(){ //匿名函数内部的$均为jQuery
$(function(){ //继续使用$()方法;
$("p").click(function(){
alert($(this).text());
});
})
})
})(jQuery) //执行匿名函数且传递实参jQuery
$("pp").style.display="none" //使用prototype

  2、jQuery库在其它库之前导入

  如果jQuey库在其它库之前导入,那么直接使用“jQuery”来做一些jQuery的工作。同时可以使用$()方法作为其它库的快捷方式。这里无需调用jQuery.noConflict()函数。

<p id="pp">隐藏元素</p>
<p>绑定单击事件</p>
<!--先引入jquery-->
<script src="../../scripts/jquery.js" type="text/javascript"></script>
<!--引入prototype-->
<script src="lib/prototype.js" type="text/javascript"></script>
<script>
jQuery(function(){ //直接使用jQuery,无需调用jQuery.noConflict();
jQuery("p").click(function(){
alert(jQuery(this).text());
});
})
$("pp").style.display="none"; //使用prototype
</script>

锋利的Jquery解惑系列(一)------基本概念大锅炖的更多相关文章

  1. 锋利的Jquery解惑系列(三)------ 各路选择器大聚会

    申明:初次学习Jquery的选择器时只记得几个和css选择器类似的几个,在这里列出书上写上的各路选择器方便以后的查询和现在的学习 所有例子都来自书上 测试画面: 一.基本选择器 #id, $(&quo ...

  2. 锋利的Jquery解惑系列(二)------插件开发大总结

    申明:插件开发是实际项目就经常用到的,不过也是挺吃力的.笔者自己做项目时,看着我们老大写的jQuery一头桨糊,那叫个痛苦.后面果断买了本参考书以及浏览别人的博客,现在也算慢慢入门了.现在总结自己的一 ...

  3. jQuery下拉框操作系列$("option:selected",this) &&(锋利的jQuery)

    jQuery下拉框操作系列$("option:selected",this)  &&(锋利的jQuery) <!DOCTYPE html> <ht ...

  4. Jquery全选系列操作(锋利的jQuery)

    Jquery全选系列操作(锋利的jQuery) <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml" ...

  5. 深入学习jQuery选择器系列第八篇——过滤选择器之伪子元素选择器

    × 目录 [1]通用形式 [2]反向形式 [3]首尾元素 [4]唯一元素 前面的话 本文是子元素选择器的续篇,主要介绍关于nth-of-type()选择器的内容.该部分内容并非没有出现在<锋利的 ...

  6. 深入学习jQuery选择器系列第一篇——基础选择器和层级选择器

    × 目录 [1]id选择器 [2]元素选择器 [3]类选择器[4]通配选择器[5]群组选择器[6]后代选择器[7]兄弟选择器 前面的话 选择器是jQuery的根基,在jQuery中,对事件处理.遍历D ...

  7. 锋利的jQuery学习总结

    通过对<锋利的jQuery>(第二版)一书的学习,发现此书讲解通俗易懂,是学习jQuery的一本很好的指导书,特作如下总结.此书主要讲解了jQuery的常用操作,包括认识jQuery,jQ ...

  8. [jQuery]《锋利的jQuery》插件部分总结

    /** * <锋利的jQuery>插件部分总结 * * jQuery插件推荐命名:jquery.name.js * * $.fn.extend用于封装对象方法的插件 * $.extend用 ...

  9. 【JQuery NoviceToNinja系列】目录

    [JQuery NoviceToNinja系列]目录 [JQuery NoviceToNinja系列]01 开篇 Html页面设计和布局

随机推荐

  1. Shell脚本编程总结及速查手册

    Shell是一种编程语言, 它像其它编程语言如: C, Java, Python等一样也有变量/函数/运算符/if语句/循环控制/… 但在开始之前, 我想先理清Shell语言与Shell之间的关系. ...

  2. cocos2d-x 2.0 拖尾效果分析

    转自:http://game.dapps.net/gamedev/game-engine/7281.html 在Cocos2d-x中,拖尾效果有一个专门的类CCMotionStreak来实现.下面我们 ...

  3. ApkTool动态打包

    引言: APK在推广的时候可能会须要动态打包APK.比方公布到不同渠道的时候,须要在manifest文件里改动渠道信息.或者app在推广的时候.须要在apk包里面加上推广人信息等. 环境变量: 1.J ...

  4. [HTTP] HTTP Verb

    HEAD: HEAD / HTTP/1.1 nc.exmaple.com HEAD is a interesting method, it allow you to get a header of f ...

  5. 在其它路径新建cocos2d-x项目

    打开vs2010程序,然后选择“文件—新建—项目”,如图 改了一下位置,放在D:\Program Files\cocos2d-x\ ,确定 然后点下一步 这个程序不需要物理引擎,所以可以把上面红色的圈 ...

  6. 局域网动态ip

    1. 局域网IP对网速没有任何影响.点“开始”“设置”进入“网络连接” 右击“本地连接”选择“属性”选中“Internet协议(TCP/IP)” 在下面的一些按钮中点“属性”,之后你可以设置局域网IP ...

  7. PHP【第一篇】安装

    一.准备 1.环境 系统平台:Red Hat Enterprise Linux Server release 7.3 (Maipo) 内核版本:3.10.0-514.el7.x86_64 2.下载安装 ...

  8. Android读取Manifest文件下Application等节点下的metadata自定义数据

    介绍 Android在 提供了meta-date使用键值对的形式实现自定义配置.一般使用中作为渠道标识.可以用 在<application>,<activity>,<ac ...

  9. 使用DrawerLayout实现QQ5.0侧拉菜单效果

    在上一篇文章中,我们介绍了怎么使用DrawerLayout来实现一个简单的侧拉菜单(使用DrawerLayout实现侧拉菜单),也就是我们常说的抽屉效果,GitHub上类似效果的实现方式非常多,实现出 ...

  10. oracle学习----trace文件

    1.查看v$diag_info视图,能查看跟踪文件的位置,具体的名称等信息. name列中,Diag Trace是11g跟踪文件所在位置 Default Trace File是当前会话的跟踪文件名 2 ...