首页 > 代码库 > jQuery常用技巧

jQuery常用技巧

 

 

1、关于页面元素的引用

通过jquery的$()引用元素包括通过id、class、元素名以及元素的层级关系及dom或者xpath条件等方法,且返回的对象为jquery对象(集合对象),不能直接调用dom定义的方法。

2、jQuery对象与dom对象的转换

只有jquery对象才能使用jquery定义的方法。注意dom对象和jquery对象是有区别的,调用方法时要注意操作的是dom对象还是jquery对象。

普通的dom对象一般可以通过$()转换成jquery对象。

如:$(document.getElementById(”msg”))则为jquery对象,可以使用jquery的方法。

由于jquery对象本身是一个集合。所以如果jquery对象要转换为dom对象则必须取出其中的某一项,一般可通过索引取出。

如:$(”#msg”)[0],$(”div”).eq(1)[0],$(”div”).get()[1],$(”td”)[5]这些都是dom对象,可以使用dom中的方法,但不能再使用Jquery的方法。

以下几种写法都是正确的:

 

$(”#msg”).html();
$(”#msg”)[0].innerHTML;
$(”#msg”).eq(0)[0].innerHTML;
$(”#msg”).get(0).innerHTML;

3、如何获取jQuery集合的某一项

 

对于获取的元素集合,获取其中的某一项(通过索引指定)可以使用eq或get(n)方法或者索引号获取,要注意,eq返回的是jquery对象,而get(n)和索引返回的是dom元素对象。对于jquery对象只能使用jquery的方法,而dom对象只能使用dom的方法,如要获取第三个<div>元素的内容。有如下两种方法:

 

$(”div”).eq(2).html();//调用jquery对象的方法
$(”div”).get(2).innerHTML;//调用dom的方法属性

4、同一函数实现set和get

 

jQuery中的很多方法都是如此,主要包括如下几个:

 

$(”#msg”).html();//返回id为msg的元素节点的html内容。
$(”#msg”).html(”<b>new content</b>”);
//将“<b>newcontent</b>” 作为html串写入id为msg的元素节点内容中,页面显示粗体的newcontent

$(”#msg”).text();//返回id为msg的元素节点的文本内容。
$(”#msg”).text(”<b>new content</b>”);
//将“<b>newcontent</b>” 作为普通文本串写入id为msg的元素节点内容中,页面显示<b>newcontent</b>

$(”#msg”).height();//返回id为msg的元素的高度
$(”#msg”).height(”300″);//将id为msg的元素的高度设为300
$(”#msg”).width();//返回id为msg的元素的宽度
$(”#msg”).width(”300″);//将id为msg的元素的宽度设为300

$(”input”).val(”);//返回表单输入框的value值
$(”input”).val(”test”);//将表单输入框的value值设为test

$(”#msg”).click();//触发id为msg的元素的单击事件
$(”#msg”).click(fn);//为id为msg的元素单击事件添加函数

同样blur,focus,select,submit事件都可以有着两种调用方法。

 

5、集合处理功能

对于jquery返回的集合内容无需我们自己循环遍历并对每个对象分别做处理,jquery已经为我们提供的很方便的方法进行集合的处理。

包括两种形式:

 

$(”p”).each(function(i){this.style.color=[‘#f00‘,‘#0f0‘,‘#00f‘][ i ]})
//为索引分别为0,1,2的p元素分别设定不同的字体颜色。

$(”tr”).each(function(i){this.style.backgroundColor=[‘#ccc‘,‘#fff‘][i%2]})
//实现表格的隔行换色效果

$(”p”).click(function(){alert($(this).html())})
//为每个p元素增加了click事件,单击某个p元素则弹出其内容

6、扩展我们需要的功能

 

 

$.extend({
min:function(a, b){return a< b?a:b;},
max:function(a, b){return a> b?a:b;}
});//为jquery扩展了min,max两个方法

使用扩展的方法(通过“$.方法名”调用):

 

 

alert(”a=10,b=20,max=”+$.max(10,20)+”,min=”+$.min(10,20));

7、支持方法的连写

 

所谓连写,即可以对一个jquery对象连续调用各种不同的方法。例如:

 

$(”p”).click(function(){alert($(this).html())})
.mouseover(function(){alert(’mouseover event’)})
.each(function(i){this.style.color=[‘#f00‘,‘#0f0‘,‘#00f‘][ i ]});

8、操作元素的样式

 

主要包括以下几种方式:

 

$(”#msg”).css(”background”);//返回元素的背景颜色
$(”#msg”).css(”background”,”#ccc”)//设定元素背景为灰色
$(”#msg”).height(300); $(”#msg”).width(”200″);//设定宽高
$(”#msg”).css({ color: “red”, background: “blue” });//以名值对的形式设定样式
$(”#msg”).addClass(”select”);//为元素增加名称为select的class
$(”#msg”).removeClass(”select”);//删除元素名称为select的class
$(”#msg”).toggleClass(”select”);//如果存在(不存在)就删除(添加)名称为select的class

9、完善的事件处理功能

 

jQuery已经为我们提供了各种事件处理方法,我们无需在html元素上直接写事件,而可以直接为通过jquery获取的对象添加事件。

 

$(”#msg”).click(function(){alert(”good”)})//为元素添加了单击事件
$(”p”).click(function(i){this.style.color=[‘#f00‘,‘#0f0‘,‘#00f‘][ i ]})
//为三个不同的p元素单击事件分别设定不同的处理

jQuery中几个自定义的事件:

 

(1)hover(fn1,fn2):一个模仿悬停事件(鼠标移动到一个对象上面及移出这个对象)的方法。当鼠标移动到一个匹配的元素上面时,会触发指定的第一个函数。当鼠标移出这个元素时,会触发指定的第二个函数。

//当鼠标放在表格的某行上时将class置为over,离开时置为out。
$(”tr”).hover(function(){
$(this).addClass(”over”);
},
function(){
$(this).addClass(”out”);
});

(2)ready(fn):当DOM载入就绪可以查询及操纵时绑定一个要执行的函数。

 

 

$(document).ready(function(){alert(”Load Success”)})
//页面加载完毕提示“Load Success”,相当于onload事件。与$(fn)等价

(3)toggle(evenFn,oddFn): 每次点击时切换要调用的函数。如果点击了一个匹配的元素,则触发指定的第一个函数,当再次点击同一元素时,则触发指定的第二个函数。随后的每次点击都重复对这两个函数的轮番调用。

 

 

//每次点击时轮换添加和删除名为selected的class。
$(”p”).toggle(function(){
$(this).addClass(”selected”);
},function(){
$(this).removeClass(”selected”);
});

(4)trigger(eventtype): 在每一个匹配的元素上触发某类事件。
例如:

 

 

$(”p”).trigger(”click”);//触发所有p元素的click事件

(5)bind(eventtype,fn),unbind(eventtype): 事件的绑定与反绑定
从每一个匹配的元素中(添加)删除绑定的事件。例如:

 

 

$(”p”).bind(”click”,function(){alert($(this).text());});//为每个p元素添加单击事件
$(”p”).unbind();//删除所有p元素上的所有事件
$(”p”).unbind(”click”)//删除所有p元素上的单击事件

10、几个实用特效功能

 

其中toggle()和slidetoggle()方法提供了状态切换功能。
阿slideToggle()方法包括了slideDown()和slideUp方法。

11、几个有用的jQuery方法

$.browser.浏览器类型:检测浏览器类型。有效参数:safari, opera, msie, mozilla。如检测是否ie:$.browser.isie,是ie浏览器则返回true。

$.each(obj,fn):通用的迭代函数。可用于近似地迭代对象和数组(代替循环)。如

 

$.each( [0,1,2],function(i,n){ alert( “Item #”+ i+ “: ”+ n ); });

等价于:

 

 

var tempArr=[0,1,2];
for(var i=0;i<tempArr.length;i++){
alert(”Item #”+i+”: “+tempArr[ i ]);
}

也可以处理json数据,如

 

 

$.each( { name: “John”, lang: “JS” },function(i,n){ alert( “Name: ”+ i+ “,Value: ”
 + n ); });

结果为:

 

 

Name:name, Value:John
Name:lang, Value:JS

$.extend(target,prop1,propN):用一个或多个其他对象来扩展一个对象,返回这个被扩展的对象。这是jquery实现的继承方式

如:

代码

$.extend(settings, options);
//合并settings和options,并将合并结果返回settings中,相当于options继承setting并将继承结果保存在
setting中。
var settings= $.extend({},defaults, options);
//合并defaults和options,并将合并结果返回到setting中而不覆盖default内容。

可以有多个参数(合并多项并返回)

 

 

$.map(array, fn):数组映射。把一个数组中的项目(处理转换后)保存到到另一个新数组中,并返回生成的新数组。

如:

 

 

var tempArr=$.map( [0,1,2],function(i){return i+ 4;});
tempArr内容为:[4,5,6]
var tempArr=$.map([0,1,2],function(i){return i> 0 ? i+ 1 :null; });
tempArr内容为:[2,3]
$.merge(arr1,arr2):合并两个数组并删除其中重复的项目。
如:$.merge( [0,1,2],[2,3,4] ) //返回[0,1,2,3,4]
$.trim(str):删除字符串两端的空白字符。
如:$.trim(”   hello, how are you? “); //返回”hello,how are you? ”

12、解决自定义方法或其他类库与jQuery的冲突

 

很多时候我们自己定义了$(id)方法来获取一个元素,或者其他的一些js类库如prototype也都定义了$方法,如果同时把这些内容放在一起就会引起变量方法定义冲突,Jquery对此专门提供了方法用于解决此问题。
使用jquery中的jQuery.noConflict();方法即可把变量$的控制权让渡给第一个实现它的那个库或之前自定义的$方法。之后应用Jquery的时候只要将所有的$换成jQuery即可,如原来引用对象方法$(”#msg”)改为jQuery(”#msg”)。
如:

 

jQuery.noConflict();
// 开始使用jQuery
jQuery(”div p”).hide();
// 使用其他库的 $()
$(”content”).style.display= ‘none’;

 

 

 

jQuery技巧总结

一、简介

1.1、概述
随着WEB2.0及ajax思想在互联网上的快速发展传播,陆续出现了一些优秀的Js框架,其中比较著名的有Prototype、YUI、jQuery、mootools、Bindows以及国内的JSVM框架等,通过将这些JS框架应用到我们的项目中能够使程序员从设计和书写繁杂的JS应用中解脱出来,将关注点转向功能需求而非实现细节上,从而提高项目的开发速度。
jQuery是继prototype之后的又一个优秀的Javascript框架。它是由 John Resig 于 2006 年初创建的,它有助于简化JavaScript™ 以及Ajax编程。有人使用这样的一比喻来比较prototype和jQuery:prototype就像Java,而jQuery就像ruby.它是一个简洁快速灵活的JavaScript框架,它能让你在你的网页上简单的操作文档、处理事件、实现特效并为Web页面添加Ajax交互。

它具有如下一些特点:
1、代码简练、语义易懂、学习快速、文档丰富。
2、jQuery是一个轻量级的脚本,其代码非常小巧,最新版的JavaScript包只有20K左右。
3、jQuery支持CSS1-CSS3,以及基本的xPath。
4、jQuery是跨浏览器的,它支持的浏览器包括IE 6.0+, FF 1.5+, Safari 2.0+, Opera 9.0+。
5、可以很容易的为jQuery扩展其他功能。
6、能将JS代码和HTML代码完全分离,便于代码和维护和修改。
7、插件丰富,除了jQuery本身带有的一些特效外,可以通过插件实现更多功能,如表单验证、tab导航、拖放效果、表格排序、DataGrid,树形菜单、图像特效以及ajax上传等。

jQuery的设计会改变你写JavaScript代码的方式,降低你学习使用JS操作网页的复杂度,提高网页JS开发效率,无论对于js初学者还是资深专家,jQuery都将是您的首选。
jQuery适合于设计师、开发者以及那些还好者,同样适合用于商业开发,可以说jQuery适合任何JavaScript应用的地方,可用于不同的Web应用程序中。
官方站点:http://jquery.com/  中文站点:http://jquery.org.cn/

1.2、目的
通过学习本文档,能够对jQuery有一个简单的认识了解,清楚JQuery与其他JS框架的不同,掌握jQuery的常用语法、使用技巧及注意事项。

二、使用方法
在需要使用JQuery的页面中引入JQuery的js文件即可。
例如:<script type="text/javascript"src="http://www.mamicode.com/js/jquery.js"></script>
引入之后便可在页面的任意地方使用jQuery提供的语法。

三、学习教程及参考资料
请参照《jQuery中文API手册》和http://jquery.org.cn/visual/cn/index.xml
推荐两篇不错的jquery教程:《jQuery的起点教程》和《使用 jQuery 简化 Ajax 开发》
(说明:以上文档都放在了【附件】中)

四、语法总结和注意事项

1、关于页面元素的引用
通过jquery的$()引用元素包括通过id、class、元素名以及元素的层级关系及dom或者xpath条件等方法,且返回的对象为jquery对象(集合对象),不能直接调用dom定义的方法。


2jQuery对象与dom对象的转换
只有jquery对象才能使用jquery定义的方法。注意dom对象和jquery对象是有区别的,调用方法时要注意操作的是dom对象还是jquery对象。
普通的dom对象一般可以通过$()转换成jquery对象。
如:$(document.getElementById("msg"))则为jquery对象,可以使用jquery的方法。
由于jquery对象本身是一个集合。所以如果jquery对象要转换为dom对象则必须取出其中的某一项,一般可通过索引取出。
如:$("#msg")[0],$("div").eq(1)[0],$("div").get()[1],$("td")[5]这些都是dom对象,可以使用dom中的方法,但不能再使用Jquery的方法。
以下几种写法都是正确的:

$("#msg").html();
$("#msg")[0].innerHTML;
$("#msg").eq(0)[0].innerHTML;
$("#msg").get(0).innerHTML;

3、如何获取jQuery集合的某一项
对于获取的元素集合,获取其中的某一项(通过索引指定)可以使用eq或get(n)方法或者索引号获取,要注意,eq返回的是jquery对象,而get(n)和索引返回的是dom元素对象。对于jquery对象只能使用jquery的方法,而dom对象只能使用dom的方法,如要获取第三个<div>元素的内容。有如下两种方法:

$("div").eq(2).html();//调用jquery对象的方法
$("div").get(2).innerHTML;//调用dom的方法属性

4、同一函数实现setget
Jquery中的很多方法都是如此,主要包括如下几个:

代码

$("#msg").html();//返回id为msg的元素节点的html内容。
$("#msg").html("<b>newcontent</b>");
//将“<b>newcontent</b>” 作为html串写入id为msg的元素节点内容中,
 页面显示粗体的newcontent

$("#msg").text();//返回id为msg的元素节点的文本内容。
$("#msg").text("<b>newcontent</b>");
//将“<b>newcontent</b>” 作为普通文本串写入id为msg的元素节点内容中,
页面显示粗体的<b>newcontent</b>

$("#msg").height();//返回id为msg的元素的高度
$("#msg").height("300");//将id为msg的元素的高度设为300
$("#msg").width();//返回id为msg的元素的宽度
$("#msg").width("300");//将id为msg的元素的宽度设为300

$("input").val("); //返回表单输入框的value值
$("input").val("test"); //将表单输入框的value值设为test

$("#msg").click(); //触发id为msg的元素的单击事件
$("#msg").click(fn); //为id为msg的元素单击事件添加函数

同样blur,focus,select,submit事件都可以有着两种调用方法

5、集合处理功能
对于jquery返回的集合内容无需我们自己循环遍历并对每个对象分别做处理,jquery已经为我们提供的很方便的方法进行集合的处理。
包括两种形式:

$("p").each(function(i){this.style.color=[‘#f00‘,‘#0f0‘,‘#00f‘]})
//为索引分别为0,1,2的p元素分别设定不同的字体颜色。

$("tr").each(function(i){this.style.backgroundColor=[‘#ccc‘,‘#fff‘][i%2]})
//实现表格的隔行换色效果

$("p").click(function(){.html())})
//为每个p元素增加了click事件,单击某个p元素则弹出其内容

6、扩展我们需要的功能

$.extend({
 min:function(a,b){return a< b?a:b;},
 max:function(a,b){return a> b?a:b;}
});//为jquery扩展了min,max两个方法
使用扩展的方法(通过“$.方法名”调用):
+",min="+$.min(10,20));

7、支持方法的连写
所谓连写,即可以对一个jquery对象连续调用各种不同的方法。
例如:

$("p").click(function(){.html())})
.mouseover(function(){})
.each(function(i){this.style.color=[‘#f00‘,‘#0f0‘,‘#00f‘]});

8、操作元素的样式
主要包括以下几种方式:

$("#msg").css("background");//返回元素的背景颜色
$("#msg").css("background","#ccc")//设定元素背景为灰色
$("#msg").height(300);$("#msg").width("200");//设定宽高
$("#msg").css({ color:"red",background:"blue" });//以名值对的形式设定样式
$("#msg").addClass("select");//为元素增加名称为select的class
$("#msg").removeClass("select");//删除元素名称为select的class
$("#msg").toggleClass("select");
//如果存在(不存在)就删除(添加)名称为select的class

9、完善的事件处理功能
Jquery已经为我们提供了各种事件处理方法,我们无需在html元素上直接写事件,而可以直接为通过jquery获取的对象添加事件。
如:

$("#msg").click(function(){})//为元素添加了单击事件
$("p").click(function(i){this.style.color=[‘#f00‘,‘#0f0‘,‘#00f‘]})

//为三个不同的p元素单击事件分别设定不同的处理
jQuery中几个自定义的事件:
(1)hover(fn1,fn2):一个模仿悬停事件(鼠标移动到一个对象上面及移出这个对象)的方法。当鼠标移动到一个匹配的元素上面时,会触发指定的第一个函数。当鼠标移出这个元素时,会触发指定的第二个函数。
//当鼠标放在表格的某行上时将class置为over,离开时置为out。

$("tr").hover(function(){
$(this).addClass("over");
},
function(){
 $(this).addClass("out");
});

(2)ready(fn):当DOM载入就绪可以查询及操纵时绑定一个要执行的函数。
$(document).ready(function(){})
//页面加载完毕提示“Load Success”,相当于onload事件。与$(fn)等价
(3)toggle(evenFn,oddFn): 每次点击时切换要调用的函数。如果点击了一个匹配的元素,则触发指定的第一个函数,当再次点击同一元素时,则触发指定的第二个函数。随后的每次点击都重复对这两个函数的轮番调用。
       //每次点击时轮换添加和删除名为selected的class。

 $("p").toggle(function(){
 $(this).addClass("selected");
 },function(){
 $(this).removeClass("selected");
 });

(4)trigger(eventtype): 在每一个匹配的元素上触发某类事件。
例如:

 $("p").trigger("click");//触发所有p元素的click事件

(5)bind(eventtype,fn),unbind(eventtype): 事件的绑定与反绑定
从每一个匹配的元素中(添加)删除绑定的事件。
例如:

$("p").bind("click",function(){.text());});
//为每个p元素添加单击事件
$("p").unbind();//删除所有p元素上的所有事件
$("p").unbind("click")//删除所有p元素上的单击事件

10、几个实用特效功能
其中toggle()和slidetoggle()方法提供了状态切换功能。
如toggle()方法包括了hide()和show()方法。
slideToggle()方法包括了slideDown()和slideUp方法。

11、几个有用的jQuery方法
$.browser.浏览器类型:检测浏览器类型。有效参数:safari, opera, msie,mozilla。如检测是否ie:$.browser.isie,是ie浏览器则返回true。
$.each(obj, fn):通用的迭代函数。可用于近似地迭代对象和数组(代替循环)。

$.each( [0,1,2],function(i,n){ ; });

等价于:

var tempArr=[0,1,2];
for(var i=0;i<tempArr.length;i++){
 ;
}

也可以处理json数据,如
$.each( { name: "John", lang: "JS" }, function(i, n){ ; });
结果为:
Name:name, Value:John
Name:lang, Value:JS
$.extend(target,prop1,propN):用一个或多个其他对象来扩展一个对象,返回这个被扩展的对象。这是jquery实现的继承方式。
如:

$.extend(settings, options);
//合并settings和options,并将合并结果返回settings中,
 相当于options继承setting并将继承结果保存在setting中。
var settings= $.extend({},defaults, options);
//合并defaults和options,并将合并结果返回到setting中而不覆盖default内容。

可以有多个参数(合并多项并返回)
$.map(array, fn):数组映射。把一个数组中的项目(处理转换后)保存到到另一个新数组中,并返回生成的
新数组。

如:

var tempArr=$.map( [0,1,2],function(i){return i+ 4;});
tempArr内容为:[4,5,6]
var tempArr=$.map([0,1,2],function(i){return i> 0 ? i+ 1 :null; });
tempArr内容为:[2,3]
$.merge(arr1,arr2):合并两个数组并删除其中重复的项目。
如:$.merge([0,1,2], [2,3,4] )//返回[0,1,2,3,4]
$.trim(str):删除字符串两端的空白字符。
如:$.trim(" hello,how are you?");//返回"hello,how are you?"

12、解决自定义方法或其他类库与jQuery的冲突
很多时候我们自己定义了$(id)方法来获取一个元素,或者其他的一些js类库如prototype也都定义了$方法,如果同时把这些内容放在一起就会引起变量方法定义冲突,Jquery对此专门提供了方法用于解决此问题。
使用jquery中的jQuery.noConflict();方法即可把变量$的控制权让渡给第一个实现它的那个库或之前自定义的$方法。之后应用Jquery的时候只要将所有的$换成jQuery即可,如原来引用对象方法$("#msg")改为jQuery("#msg")。
如:

jQuery.noConflict();
// 开始使用jQuery
jQuery("div p").hide();
// 使用其他库的 $()
$("content").style.display= ‘none‘;

 

 

 

 

 

了解jQuery技巧来提高你的代码

  jQuery之所以如此流行并被从大公司到个人博客的几乎每个人都广泛使用,是因为它上手和使用相当简单,而且为我们提供了一些人都不知道的相当棒的特性。我认为jQuery的大多数用户更趋向于使用jQuery插件来解决面临的难题,这通常是明智的选择。但是当插件相对于你的需求有一定缺陷的时候,你也许更应该想办法自己来解决,下面来看看这些实用的jQuery技巧,他们肯定会能够派上用场的!

  1.测试并提升你的jQuery选择器水平

  这个jQuery选择器实验室非常酷,它能在线免费使用,当然你也能下来到本地离线使用。这个测试页面包含复杂的HTML组合字段,然后你能尝试预定义使用各种jQuery选择器。如果这还不够你也可以自定义选择器。

 

  2.测试jQuery包装集是否包含某些元素

  如果你想测试一下某个jQuery包装集中是否包含某些元素,你首先可以尝试使用验证首个元素是否存在:

if($(selector)[0]){}
// 或者这样
if($(selector).length){}

来看看这个例子:

 //例子.如果你的页面有以下html代码
<ulid="shopping_cart_items">
<li><inputclass="in_stock" name="item" type="radio" value="http://www.mamicode.com/Item-X" />ItemX</li>
<li><inputclass="unknown" name="item" type="radio" value="http://www.mamicode.com/Item-Y" />ItemY</li>
<li><inputclass="in_stock" name="item" type="radio" value="http://www.mamicode.com/Item-Z" />ItemZ</li>
</ul>
<preescaped="true" lang="javascript">
//这个if条件将返回true,因为我们有两个
// input域匹配了选择器,所以<statement>代码将会执行
if($(‘#shopping_cart_items input.in_stock‘)[0]){<statement>}

  3.jquery.org读取jQuery最新版本

  你可以使用这句代码读取jQuery的最新版本的代码文件。

<scriptsrc="http://code.jquery.com/jquery-latest.js"></script>

  你可以使用这个方法来调用最近版本的jQuery框架,当然,你还可以使用下面这个代码从ajax.googleapis.com调用同样的最新版本jQuery:

<scriptsrc="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"
type="text/javascript"></script>

  4.存储数据
  使用data方法可以避免在DOM中存储数据,有些前端开发er喜欢使用HTML的属性来存储数据:

$(‘selector‘).attr(‘alt‘,‘databeing stored‘);
//之后可以这样读取数据:
$(‘selector‘).attr(‘alt‘);

  使用”alt”属性来作为参数名存储数据其实对于HTML来说是不符合语义的,我们可以使用jQuery的data方法来为页面中的某个元素存储数据

$(‘selector‘).data(‘参数名‘,‘要存储的数据‘);

 //之后这样取得数据:
$(‘selector‘).data(‘参数‘);

  这个data方法能让你自己明明数据的参数,更语义更灵活,你可以在页面上的任何元素存储数据信息。如果想了解更多关于data()和removeData()方法的介绍,可以看看jQuery官方讲解。

  这个方法的经典应用是给input域一个默认值,然后在聚焦的时候清空它:

  HTML部分:

<formid="testform">

<inputtype="text" class="clear" value="http://www.mamicode.com/Always" />
<inputtype="text" class="clearonce" value="http://www.mamicode.com/Cleared" />
<inputtype="text" value="http://www.mamicode.com/Normal text" />
</form>

  JavaSript部分:

$(function(){

//取出有clear类的input域
 //(注:"clear once" 是两个class clear 和 once)
 $(‘#testforminput.clear‘).each(function(){
//使用data方法存储数据
 $(this).data("txt",$.trim($(this).val()) );
 }).focus(function(){
// 获得焦点时判断域内的值是否和默认值相同,如果相同则清空
 if ( $.trim($(this).val())=== $(this).data("txt")) {
 $(this).val("");
 }
 }).blur(function(){
// 为有classclear的域添加blur时间来恢复默认值
 // 但如果class是once则忽略
 if ( $.trim($(this).val())=== "" && !$(this).hasClass("once")) {
//Restore saved data
 $(this).val($(this).data("txt") );
 }
 });
});

查看Demo

  5.jQuery手册常备身边

  大多数人都很难记住所有的编程细节,即使再好的程序员也会有对某个程序语言的疏忽大意,所以把相关的手册打印出来或随时放在桌面上进行查阅绝对是可以提高编程效率的。

  oscarotero jquery 1.3 (壁纸版)

 

  6.FireBug控制台记录jQuery

  FireBug是我最喜欢用的一个浏览器扩展工具之一,这个工具可以让你快速的在可视化界面中了解当前页面的HTML+CSS+JavaScript,并在该工具下完成即时开发。作为jQuery或JavaScript开发人员,FireFox对于 记录你的JavaScript代码 也得到支持。

  写入FireBug控制台的最简单方式如下:

 

console.log("helloworld")

  你也可以按照你希望的方式写一些参数:

console.log(2,4,6,8,"foo",bar)

  你也可以编写一个小扩展来记录jQuery对象到控制台:

jQuery.fn.log= function(msg){

console.log("%s: %o", msg,this);
return this;
};

  对于这个扩展,你可以直接使用.log()方法来记录当前对象到控制台。

$(‘#some_div‘).find(‘li.source> input:checkbox‘)
 .log("sources to uncheck")
 .removeAttr("checked");

  7.尽可能使用ID选择器

  在使用jQuery之后,你会发现利用class属性来选择DOM元素变得相当简单。尽管如此,还是推荐大家尽量少用class选择器取而代之尽量多使用运行更快的ID选择器(IE浏览器下使用class选择器会在遍历整个DOM树之后返回相符的class包装集)。而ID选择器更快是因为DOM本身就有”天然的”getElementById这个方法,而class并没有。所以如果使用class选择器的话,浏览器会遍历整个DOM,如果你的网页DOM结构足够复杂,这些class选择器足矣把页面拖得越来越慢。让我们看看这段简单的HTML代码:

<divid="main">
<formmethod="post" action="/">
<h2>Selectorsin jQuery</h2>
 ...
<inputclass="button" id="main_button" type="submit" value="http://www.mamicode.com/Submit" />
</form>
</div>

 

 //使用class来调用submit按钮要比使用绝对的ID选择器慢很多
var main_button= $(‘#main.button‘);
var main_button= $(‘#main_button‘);

  8.善于利用jQuery

  jQuery链不但允许以简洁的方式写出强大的操作,而且提高了开发效率,因为它能够把多个命令应用到包装集,而不必重新计算包装集。从而你不用再这样写了:

<li>Description:<inputtype="text" name="description" value="" /></li>

 

$(‘#shopping_cart_itemsinput.text‘).css(‘border‘,‘3px dashed yellow‘);
$(‘#shopping_cart_items input.text‘).css(‘background-color‘,‘red‘);
$(‘#shopping_cart_items input.text‘).val("text updated");

  取而代之你可以使用jQuery链来完成简便的操作:

var input_text= $(‘#shopping_cart_itemsinput.text‘);
input_text.css(‘border‘,‘3px dashed yellow‘);
input_text.css(‘background-color‘,‘red‘);
input_text.val("text updated");

//same with chaining:
var input_text= $(‘#shopping_cart_itemsinput.text‘);
input_text
 .css(‘border‘,‘3px dashed yellow‘)
 .css(‘background-color‘,‘red‘)
 .val("text updated");

  9.绑定jQuery函数到$(window).load事件

  大多数jQuery实例或教程都告诉我们绑定我们的jQuery代码到$(document).ready事件。虽然$(document).ready事件在大多数情况下都OK,但是它的解析顺序是在文档准备就绪,单文档中的图片等对象正在下载的时候开始运行的。所以在某些时候使用$(document).ready事件并不一定能达到我们预期的效果,比如一些视觉效果和动画、拖拽、预读取隐藏图片等…通过使用$(window).load事件便可以安全的在整个文档都准备就绪之后再开始运行你期望的代码。

$(window).load(function(){
// 将你希望在页面完全就绪之后运行的代码放在这里
});

  10.使用jQuery链来限定选择器,让你的代码更简洁更优雅

  由于JavaScript支持链结构而且支持断行,所以你的代码可以写成下面这样,这个例子先在元素上移除一个class然后在同一个元素上添加另一个class:

$(‘#shopping_cart_itemsinput.in_stock‘)
 .removeClass(‘in_stock‘)
 .addClass(‘3-5_days‘);

  如果想让它更简单实用,你可以创建一个支持链结构的jQuery函数:

$.fn.makeNotInStock= function() {
return $(this).removeClass(‘in_stock‘).addClass(‘3-5_days‘);
}

 $(‘#shopping_cart_itemsinput.in_stock‘).makeNotInStock().log();

  11.使用回调函数同步效果

  如果你想确保某个事件或动画效果要在另一个事件运行之后再调用,那你就要使用回调函数了。你可以在这些动画效果后面绑定回调函数:slideDown( speed, [回调] ) ie. $(’#sliding’).slideDown(’slow’, function(){… 点击这里预览这个例子。

<style>
 div.button{ background:#cfd; margin:3px; width:50px;
 text-align:center; float:left; cursor:pointer;
 border:2pxoutset black; font-weight:bolder; }
 #sliding{ display:none; }
</style>

 

$(document).ready(function(){
// 使用jQuery的click事件改变视觉效果,并开启滑动效果
 $("div.button").click(function () {
//div.button 现在看上去是按下的效果
 $(this).css({borderStyle:"inset", cursor:"wait" });
//#sliding 现在将渐隐并在完成动作之后开启渐显效果
 //slideup once itcompletes
 $(‘#sliding‘).slideDown(‘slow‘,function(){
 $(‘#sliding‘).slideUp(‘slow‘,function(){
//渐显效果完成后将会改变按钮的CSS属性
 $(‘div.button‘).css({borderStyle:"outset", cursor:"auto" });
 });
 });
 });
});

  12.学会使用自定义选择器

  jQuery允许我们在css选择器的基础上定义自定义选择器来让我们的代码更简洁:

$.expr[‘:‘].mycustomselector= function(element,index, meta, stack){
// element-DOM元素
 // index - 堆栈中当前遍历的索引值
 // meta - 关于你的选择器的数据元
 // stack - 用于遍历所有元素的堆栈
 
// 包含当前元素则返回true
 // 不包含当前元素则返回false
};

// 自定义选择器的应用:
$(‘.someClasses:test‘).doSomething();

  下面让我们来看看一个小例子,我们通过使用自定义选择器来锁定含有”rel”属性的元素集:

$.expr[‘:‘].withRel= function(element){
var $this = $(element);
//仅返回rel属性不为空的元素
 return ($this.attr(‘rel‘)!= ‘‘);
};

 $(document).ready(function(){
//自定义选择器的使用很简单,它和其他选择器一样,返回一个元素包装集
//你可以为他使用格式方法,比如下面这样修改它的css样式
 $(‘a:withRel‘).css(‘background-color‘,‘green‘);
});

 

<ul>
<li>
<ahref="http://www.mamicode.com/#">withoutrel</a>
</li>
<li>
<arel="somerel" href="http://www.mamicode.com/#">withrel</a>
</li>
<li>
<arel="" href="http://www.mamicode.com/#">withoutrel</a>
</li>
<li>
<arel="nofollow" href="http://www.mamicode.com/#">alink with rel</a>
</li>
</ul>

 

  13.预加载图片

  通常使用JavaScript来预加载图片是个相当不错的方法:

//定义预加载图片列表的函数(有参数)  
jQuery.preloadImages= function(){
//遍历图片
 for(var i= 0;i<arguments.length; i++){
 jQuery("<img>").attr("src",arguments[i]);
 }
}
// 你可以这样使用预加载函数
$.preloadImages("images/logo.png","images/logo-face.png","images/mission.png");

 

  14.将你的代码测试完好

  jQuery有一个名为QUnit单元测试框架。编写测试很容易,它能让您可以放心地修改您的代码,并确保它仍然按预期工作。下面是如何工作的:

//将测试分成若干模块.
module("Module B");
 test("some other test",function() {
//指定多少个判断语句需要加入测试中.
 expect(2);
 equals(true,false,"failingtest" );
 equals(true,true,"passingtest" );
});

 

 

 

 

豆瓣的jQuery使用技巧

 

Douban是2.0 社区里面比较成功的一个产品, 里面ajax技术也做得不错, 把它的源码拿来研究了一下, 它在页面上使用了jquery, 我比较喜欢它的一体式的事件处理机制,不用写很多的事件绑定代码,只需要通过一定的命名规则就可以自动给页面元素加上一些功能, 它上面几乎所有的功能都通过这个实现, 配合jquery强大的选择器,代码看起来比较简洁清晰.  下面我们就来看看它的一些核心部分. 我使用的是jquery 1.2.3,压缩之后29kb大小, 速度感觉上比以前有比较大的改善.废话不多说了,直接看看代码吧. 另外推荐一下blueprint 这个css框架,还挺好用的.


//定义命名空间
var Bowtech=newObject();

//注册全局的事件监视器.
Bowtech.EventMonitor= function(){
    this.listeners = newObject();
}
//广播事件
Bowtech.EventMonitor.prototype.broadcast=function(widgetObj, msg, data){
    var lst = this.listeners[msg];

    if(lst != null){
        for(var o in lst){
            lst[o](widgetObj, data);
        }
    }
}
//绑定所有的事件.
Bowtech.EventMonitor.prototype.subscribe=function(msg, callback){
    var lst = this.listeners[msg];
    if (lst) {
        lst.push(callback);
    } else {
        this.listeners[msg]= [callback];
    }
}
//取消事件绑定.
Bowtech.EventMonitor.prototype.unsubscribe=function(msg, callback){
    var lst = this.listener[msg];
    if (lst != null){
        lst = lst.filter(function(ele, index, arr){return ele!=callback;});
    }
}

// Pagescope event-monitor obj.
var event_monitor = newBowtech.EventMonitor();
//对于所有class="j a_xxx yyy" id="xxx-123"的元素执行事件绑定, xxx-123部分用来获取元素的ID,比如一个帖子的ID,
//a_xxx  后面的部
//分用来标识应用如 vote / review / blog 等.
//绑定的事件就是 :  Bowtech.init_vote/ Bowtech.init_blog 等.
function load_event_monitor(root) {
    var re = /a_(\w+)/; //正则表达式获取ID.
    var fns = {};
    $(".j", root).each(function(i) {
        var m =re.exec(this.className);
        if (m) {
            var f =fns[m[1]];
            if (!f) {//如果事件处理函数不存在则创建函数对象.
                f =eval("Bowtech.init_"+m[1]);
                fns[m[1]] = f;//调用绑定函数.
            }
            f && f(this);
        }
    });
}
//在文档加载完毕后将执行的方法(参见jquery文档)
//一般来说文档加载的时候应该绑定所有的事件, 但是有一种情况例外.
//比如 通过Ajax方法取回来的内容里面还含有动作按钮的,这时需要针对这部分功能执行绑定.
//需要手动调用load_event_monitor(element);  方法.
$(function() {
    load_event_monitor(document);
});
//注意这里的o对象是一个html 元素而非是一个jquery对象,所以在调用它的方法时应该使用$(o)函数
//把它转化为jquery对象.
Bowtech.init_forder= function(o) {
    var eid =$(o).attr("id").split("-")[1];
    var fo = $("#f-"+eid);
    var unfo = $("#unf-"+eid);
   
    fo.click(function() {
       $(o).hide();
       unfo.show();
       fo.hide();
    });
    unfo.click(function() {
        $(o).show();
        fo.show();
        unfo.hide();
    });
}


jQuery.fn.extend({
    set_caret: function(){
        if(!$.browser.msie)return;
        varinitSetCaret = function(){this.caretPos =document.selection.createRange().duplicate()};
        this.click(initSetCaret).select(initSetCaret).keyup(initSetCaret);
    },
    insert_caret:function(textFeildValue){
        vartextObj = this[0];
        if(document.all&& textObj.createTextRange && textObj.caretPos){
           varcaretPos=textObj.caretPos;
            caretPos.text =caretPos.text.charAt(caretPos.text.length-1) == ‘‘ ? textFeildValue+‘‘ :textFeildValue;
        } else if(textObj.setSelectionRange){
            varrangeStart=textObj.selectionStart;
            varrangeEnd=textObj.selectionEnd;
            vartempStr1=textObj.value.substring(0,rangeStart);
            vartempStr2=textObj.value.substring(rangeEnd);
           textObj.value=http://www.mamicode.com/tempStr1+textFeildValue+tempStr2;
            textObj.focus();
            varlen=textFeildValue.length;
           textObj.setSelectionRange(rangeStart+len,rangeStart+len);
            textObj.blur();
        } else {
            textObj.value+=textFeildValue;
        }
    }
})


前台要用就比较简单了,  只需要这样写:

<div id="test2" class="mod">
                <h3>
                    这里可以放标题
                h3>
                <div class="jmodb a_forder" id="modb-1002">
                    这里是一些主要的内容
                    <dl>
                        <dt>Helloworlddt>
                        <dd>
                            hahahadd>
                    dl>
                    这个实验在沙加的神舟本上完成
                div>
                <div class="edit">
                    <a id="f-1002" class="forder" href="javascript:void(0);">[收起]a> <a id="unf-1002"
                        class="unforder" href="javascript:void(0);">[展开]a>
                div>
            div>


样式就省略了, 大家可以自己写, 最后发两个效果图:

收起时的样子

 

JQuery常用方法基础教程

对于学习使用jquery 的朋友,能用的到,简单的了解下jquery的一些操作。

  $(”p”).addClass(css中定义的样式类型); 给某个元素添加样式

  $(”img”).attr({src:”test.jpg”,alt:”testImage”}); 给某个元素添加属性/值,参数是map

  $(”img”).attr(”src”,”test.jpg”);给某个元素添加属性/值

  $(”img”).attr(”title”, function() { returnthis.src }); 给某个元素添加属性/值

  $(”元素名称”).html(); 获得该元素内的内容(元素,文本等)

  $(”元素名称”).html(”new stuff”); 给某元素设置内容

  $(”元素名称”).removeAttr(”属性名称”)给某元素删除指定的属性以及该属性的值

  $(”元素名称”).removeClass(”class”)给某元素删除指定的样式

  $(”元素名称”).text(); 获得该元素的文本

  $(”元素名称”).text(value); 设置该元素的文本值为value

  $(”元素名称”).toggleClass(class) 当元素存在参数中的样式的时候取消,如果不存在就设置此样式

  $(”input元素名称”).val();获取input元素的值

  $(”input元素名称”).val(value);设置input元素的值为value

  Manipulation:

  $(”元素名称”).after(content); 在匹配元素后面添加内容

  $(”元素名称”).append(content); 将content作为元素的内容插入到该元素的后面

  $(”元素名称”).appendTo(content); 在content后接元素

  $(”元素名称”).before(content); 与after方法相反

  $(”元素名称”).clone(布尔表达式) 当布尔表达式为真时,克隆元素(无参时,当作true处理)

  $(”元素名称”).empty() 将该元素的内容设置为空

  $(”元素名称”).insertAfter(content); 将该元素插入到content之后

  $(”元素名称”).insertBefore(content); 将该元素插入到content之前

  $(”元素”).prepend(content); 将content作为该元素的一部分,放到该元素的最前面

  $(”元素”).prependTo(content); 将该元素作为content的一部分,放content的最前面

  $(”元素”).remove(); 删除所有的指定元素

  $(”元素”).remove(”exp”); 删除所有含有exp的元素

  $(”元素”).wrap(”html”); 用html来包围该元素

  $(”元素”).wrap(element); 用element来包围该元素

  Traversing:

  add(expr)

  add(html)

  add(elements)

  children(expr)

  contains(str)

  end()

  filter(expression)

  filter(filter)

  find(expr)

  is(expr)

  next(expr)

  not(el)

  not(expr)

  not(elems)

  parent(expr)

  parents(expr)

  prev(expr)

  siblings(expr)

  Core:

  $(html).appendTo(”body”) 相当于在body中写了一段html代码

  $(elems) 获得DOM上的某个元素

  $(function(){……..}); 执行一个函数

  $(”div > p”).css(”border”,“1px solid gray”); 查找所有div的子节点p,添加样式

  $(”input:radio”, document.forms[0]) 在当前页面的第一个表单中查找所有的单选按钮

  $.extend(prop) prop是一个jquery对象,

  举例:

  jQuery.extend({

  min: function(a, b) { return a < b ? a : b; },

  max: function(a, b) { return a > b ? a : b; }

  });

  jQuery( expression, [context] ) —$( expression,[context]); 在默认情况下,$()查询的是当前HTML文档中的DOM元素。

  each( callback ) 以每一个匹配的元素作为上下文来执行一个函数

  举例:1

  $(”span”).click(function){

  $(”li”).each(function(){

  $(this).toggleClass(”example”);

  });

  });

  举例:2

  $(”button”).click(function () {

  $(”div”).each(function (index, domEle) {

  // domEle == this

  $(domEle).css(”backgroundColor”, “yellow”);

  if ($(this).is(”#stop”)) {

  $(”span”).text(”Stopped at div index#” + index);

  return false;

  }

  });

  });

  jQuery Event:

  ready(fn); $(document).ready()注意在body中没有onload事件,否则该函数不能执行。在每个页面中可以

  有很多个函数被加载执行,按照fn的顺序来执行。

  bind( type, [data], fn ) 为每一个匹配元素的特定事件(像click)绑定一个或多个事件处理器函数。可能的事件属性有:blur,focus, load, resize, scroll, unload, click, dblclick, mousedown, mouseup,mousemove,

  mouseover, mouseout, mouseenter, mouseleave, change, select,submit, keydown, keypress,

  keyup, error

  one( type, [data], fn ) 为每一个匹配元素的特定事件(像click)绑定一个或多个事件处理器函数。在每个对

  象上,这个事件处理函数只会被执行一次。其他规则与bind()函数相同。

  trigger( type, [data] ) 在每一个匹配的元素上触发某类事件。

  triggerHandler( type, [data] ) 这一特定方法会触发一个元素上特定的事件(指定一个事件类型),同时取消浏览器对此事件的默认行动

  unbind( [type], [data] ) 反绑定,从每一个匹配的元素中删除绑定的事件。

  $(”p”).unbind() 移除所有段落上的所有绑定的事件

  $(”p”).unbind( “click” ) 移除所有段落上的click事件

  hover( over, out ) over,out都是方法, 当鼠标移动到一个匹配的元素上面时,会触发指定的第一个函数。当鼠标移出这个元素时,会触发指定的第二个函数。

  $(”p”).hover(function(){

  $(this).addClass(”over”);

  },

  function(){

  $(this).addClass(”out”);

  }

  );

  toggle( fn, fn ) 如果点击了一个匹配的元素,则触发指定的第一个函数,当再次点击同一元素时,则触发指定的第二个函数。

  $(”p”).toggle(function(){

  $(this).addClass(”selected”);

  },

  function(){

  $(this).removeClass(”selected”);

  }

  );

  元素事件列表说明

  注:不带参数的函数,其参数为可选的 fn。jQuery不支持form元素的reset事件。

  事件描述 支持元素或对象

  blur( ) 元素失去焦点 a, input, textarea, button, select, label, map, area

  change( ) 用户改变域的内容 input, textarea, select

  click( ) 鼠标点击某个对象几乎所有元素

  dblclick( ) 鼠标双击某个对象几乎所有元素

  error( ) 当加载文档或图像时发生某个错误 window, img

  focus( ) 元素获得焦点 a, input, textarea, button, select, label, map, area

  keydown( ) 某个键盘的键被按下几乎所有元素

  keypress( ) 某个键盘的键被按下或按住几乎所有元素

  keyup( ) 某个键盘的键被松开几乎所有元素

  load( fn ) 某个页面或图像被完成加载 window, img

  mousedown( fn ) 某个鼠标按键被按下几乎所有元素

  mousemove( fn ) 鼠标被移动几乎所有元素

  mouseout( fn ) 鼠标从某元素移开几乎所有元素

  mouseover( fn ) 鼠标被移到某元素之上几乎所有元素

  mouseup( fn ) 某个鼠标按键被松开几乎所有元素

  resize( fn ) 窗口或框架被调整尺寸 window, iframe, frame

  scroll( fn ) 滚动文档的可视部分时 window

  select( ) 文本被选定 document, input, textarea

  submit( ) 提交按钮被点击 form

  unload( fn ) 用户退出页面 window

  JQuery Ajax 方法说明:

  load( url, [data], [callback] ) 装入一个远程HTML内容到一个DOM结点。

  $(”#feeds”).load(”feeds.html”);将feeds.html文件载入到id为feeds的div中

  $(”#feeds”).load(”feeds.php”,{limit: 25}, function(){

  alert(”The last 25 entries in the feed have beenloaded”);

  });

  jQuery.get( url, [data], [callback] ) 使用GET请求一个页面。

  $.get(”test.cgi”, { name: “John”,time: “2pm” }, function(data){

  alert(”Data Loaded: ” + data);

  });

  jQuery.getJSON( url, [data], [callback] ) 使用GET请求JSON数据。

  $.getJSON(”test.js”, { name: “John”,time: “2pm” }, function(json){

  alert(”JSON Data: ” +json.users[3].name);

  });

  jQuery.getScript( url, [callback] ) 使用GET请求javascript文件并执行。

  $.getScript(”test.js”, function(){

  alert(”Script loaded and executed.”);

  });

  jQuery.post( url, [data], [callback], [type] ) 使用POST请求一个页面。

  ajaxComplete( callback ) 当一个AJAX请求结束后,执行一个函数。这是一个Ajax事件

  $(”#msg”).ajaxComplete(function(request, settings){

  $(this).append(”

  • Request Complete.”);

  });

  ajaxError( callback ) 当一个AJAX请求失败后,执行一个函数。这是一个Ajax事件

  $(”#msg”).ajaxError(function(request, settings){

  $(this).append(”

  • Error requesting page” + settings.url + “”);

  });

  ajaxSend( callback ) 在一个AJAX请求发送时,执行一个函数。这是一个Ajax事件

  $(”#msg”).ajaxSend(function(evt, request,settings){

  $(this).append(”

  • < p>

  + “<”);< p>

  });

  ajaxStart( callback ) 在一个AJAX请求开始但还没有激活时,执行一个函数。这是一个Ajax事件

  当AJAX请求开始(并还没有激活时)显示loading信息

  $(”#loading”).ajaxStart(function(){

  $(this).show();

  });

  ajaxStop( callback ) 当所有的AJAX都停止时,执行一个函数。这是一个Ajax事件

  当所有AJAX请求都停止时,隐藏loading信息。

  $(”#loading”).ajaxStop(function(){

  $(this).hide();

  });

  ajaxSuccess( callback ) 当一个AJAX请求成功完成后,执行一个函数。这是一个Ajax事件

  当AJAX请求成功完成时,显示信息。

  $(”#msg”).ajaxSuccess(function(evt, request,settings){

  $(this).append(”

  •  
  • Successful Request!”);

  });

  jQuery.ajaxSetup( options ) 为所有的AJAX请求进行全局设置。查看$.ajax函数取得所有选项信息。

  设置默认的全局AJAX请求选项。

  $.ajaxSetup({

  url: “/xmlhttp/”,

  global: false,

  type: “POST”

  });

  $.ajax({ data: myData });

  serialize( ) 以名称和值的方式连接一组input元素。实现了正确表单元素序列

  function showValues() {

  var str = $(”form”).serialize();

  $(”#results”).text(str);

  }

  $(”:checkbox, :radio”).click(showValues);

  $(”select”).change(showValues);

  showValues();

  serializeArray( ) 连接所有的表单和表单元素(类似于.serialize()方法),但是返回一个JSON数据格式。

  从form中取得一组值,显示出来

  function showValues() {

  var fields = $(”:input”).serializeArray();

  alert(fields);

  $(”#results”).empty();

  jQuery.each(fields, function(i, field){

  $(”#results”).append(field.value + ”“);

  });

  }

  $(”:checkbox, :radio”).click(showValues);

  $(”select”).change(showValues);

  showValues();

  JQuery Effects 方法说明

  show( ) 显示隐藏的匹配元素。

  show( speed, [callback] ) 以优雅的动画显示所有匹配的元素,并在显示完成后可选地触发一个回调函数。

  hide( ) 隐藏所有的匹配元素。

  hide( speed, [callback] ) 以优雅的动画隐藏所有匹配的元素,并在显示完成后可选地触发一个回调函数

  toggle( ) 切换元素的可见状态。如果元素是可见的,切换为隐藏的;如果元素是隐藏的,

  切换为可见的。

  slideDown( speed, [callback] ) 通过高度变化(向下增大)来动态地显示所有匹配的元素,在显示完成后可选

  地触发一个回调函数。这个动画效果只调整元素的高度,可以使匹配的元素以

  “滑动”的方式显示出来。

  slideUp( speed, [callback] ) 通过高度变化(向上减小)来动态地隐藏所有匹配的元素,在隐藏完成后可选地

  触发一个回调函数。这个动画效果只调整元素的高度,可以使匹配的元素以”滑动”

  的方式隐藏起来。

  slideToggle( speed, [callback] ) 通过高度变化来切换所有匹配元素的可见性,并在切换完成后可选地触发一个回

  调函数。这个动画效果只调整元素的高度,可以使匹配的元素以”滑动”的方式隐

  藏或显示。

  fadeIn( speed, [callback] ) 通过不透明度的变化来实现所有匹配元素的淡入效果,并在动画完成后可选地触

  发一个回调函数。这个动画只调整元素的不透明度,也就是说所有匹配的元素的

  高度和宽度不会发生变化。

  fadeOut( speed, [callback] ) 通过不透明度的变化来实现所有匹配元素的淡出效果,并在动画完成后可选地触

  发一个回调函数。这个动画只调整元素的不透明度,也就是说所有匹配的元素的

  高度和宽度不会发生变化。

  fadeTo( speed, opacity, [callback] ) 把所有匹配元素的不透明度以渐进方式调整到指定的不透明度,并在动画完成

  后可选地触发一个回调函数。这个动画只调整元素的不透明度,也就是说所

  有匹配的元素的高度和宽度不会发生变化。

  stop( ) 停止所有匹配元素当前正在运行的动画。如果有动画处于队列当中,他们就会立即开始。

  queue( ) 取得第一个匹配元素的动画序列的引用(返回一个内容为函数的数组)

  queue( callback ) 在每一个匹配元素的事件序列的末尾添加一个可执行函数,作为此元素的事件函数

  queue( queue ) 以一个新的动画序列代替所有匹配元素的原动画序列

  dequeue( ) 执行并移除动画序列前端的动画

  animate( params, [duration], [easing], [callback] ) 用于创建自定义动画的函数。

  animate( params, options ) 创建自定义动画的另一个方法。作用同上。

  JQuery Traversing 方法说明

  eq( index ) 从匹配的元素集合中取得一个指定位置的元素,index从0开始

  filter( expr ) 返回与指定表达式匹配的元素集合,可以使用”,”号分割多个expr,用于实现多个条件筛选

  filter( fn ) 利用一个特殊的函数来作为筛选条件移除集合中不匹配的元素。

  is( expr ) 用一个表达式来检查当前选择的元素集合,如果其中至少有一个元素符合这个给定的

  表达式就返回true。

  map( callback ) 将jQuery对象中的一组元素利用callback方法转换其值,然后添加到一个jQuery数组中。

  not( expr ) 从匹配的元素集合中删除与指定的表达式匹配的元素。

  slice( start, [end] ) 从匹配元素集合中取得一个子集,和内建的数组的slice方法相同。

  add( expr ) 把与表达式匹配的元素添加到jQuery对象中。

  children( [expr] ) 取得一个包含匹配的元素集合中每一个元素的所有子元素的元素集合。可选的过滤器

  将使这个方法只匹配符合的元素(只包括元素节点,不包括文本节点)。

  contents( ) 取得一个包含匹配的元素集合中每一个元素的所有子孙节点的集合(只包括元素节点,不

  包括文本节点),如果元素为iframe,则取得其中的文档元素

  find( expr ) 搜索所有与指定表达式匹配的元素。

  next( [expr] ) 取得一个包含匹配的元素集合中每一个元素紧邻的后面同辈元素的元素集合。

  nextAll( [expr] ) 取得一个包含匹配的元素集合中每一个元素所有的后面同辈元素的元素集合

  parent( [expr] ) 取得一个包含着所有匹配元素的唯一父元素的元素集合。

  parents( [expr] ) 取得一个包含着所有匹配元素的唯一祖先元素的元素集合(不包含根元素)。

  prev( [expr] ) 取得一个包含匹配的元素集合中每一个元素紧邻的前一个同辈元素的元素集合。

  prevAll( [expr] ) 取得一个包含匹配的元素集合中每一个元素的之前所有同辈元素的元素集合。

  siblings( [expr] ) 取得一个包含匹配的元素集合中每一个元素的所有同辈元素的元素集合。

  andSelf( ) 将前一个匹配的元素集合添加到当前的集合中

  取得所有div元素和其中的p元素,添加border类属性。取得所有div元素中的p元素,

  添加background类属性

  $(”div”).find(”p”).andSelf().addClass(”border”);

  $(”div”).find(”p”).addClass(”background”);

  end( ) 结束当前的操作,回到当前操作的前一个操作

  找到所有p元素其中的span元素集合,然后返回p元素集合,添加css属性

  $(”p”).find(”span”).end().css(”border”,“2px red solid”);

  JQuery Selectors 方法说明

  基本选择器

  $(”#myDiv”) 匹配唯一的具有此id值的元素

  $(”div”) 匹配指定名称的所有元素

  $(”.myClass”) 匹配具有此class样式值的所有元素

  $(”*”) 匹配所有元素

  $(”div,span,p.myClass”) 联合所有匹配的选择器

  层叠选择器

  $(”form input”) 后代选择器,选择ancestor的所有子孙节点

  $(”#main > *”) 子选择器,选择parent的所有子节点

  $(”label + input”) 临选择器,选择prev的下一个临节点

  $(”#prev ~ div”) 同胞选择器,选择prev的所有同胞节点

  基本过滤选择器

  $(”tr:first”) 匹配第一个选择的元素

  $(”tr:last”) 匹配最后一个选择的元素

  $(”input:not(:checked) + span”)从原元素集合中过滤掉匹配selector的所有元素(这里有是一个临选择器)

  $(”tr:even”) 匹配集合中偶数位置的所有元素(从0开始)

  $(”tr:odd”) 匹配集合中奇数位置的所有元素(从0开始)

  $(”td:eq(2)”) 匹配集合中指定位置的元素(从0开始)

  $(”td:gt(4)”) 匹配集合中指定位置之后的所有元素(从0开始)

  $(”td:gl(4)”) 匹配集合中指定位置之前的所有元素(从0开始)

  $(”:header”) 匹配所有标题

  $(”div:animated”) 匹配所有正在运行动画的所有元素

  内容过滤选择器

  $(”div:contains(‘John‘)”) 匹配含有指定文本的所有元素

  $(”td:empty”) 匹配所有空元素(只含有文本的元素不算空元素)

  $(”div:has(p)”) 从原元素集合中再次匹配所有至少含有一个selector的所有元素

  $(”td:parent”) 匹配所有不为空的元素(含有文本的元素也算)

  $(”div:hidden”) 匹配所有隐藏的元素,也包括表单的隐藏域

  $(”div:visible”) 匹配所有可见的元素

  属性过滤选择器

  $(”div[id]”) 匹配所有具有指定属性的元素

  $(”input[name=‘newsletter‘]”) 匹配所有具有指定属性值的元素

  $(”input[name!=‘newsletter‘]”) 匹配所有不具有指定属性值的元素

  $(”input[name^=‘news‘]”) 匹配所有指定属性值以value开头的元素

  $(”input[name$=‘letter‘]”) 匹配所有指定属性值以value结尾的元素

  $(”input[name*=‘man‘]”) 匹配所有指定属性值含有value字符的元素

  $(”input[id][name$=‘man‘]”) 匹配同时符合多个选择器的所有元素

  子元素过滤选择器

  $(”ul li:nth-child(2)”),

  $(”ul li:nth-child(odd)”), 匹配父元素的第n个子元素

  $(”ul li:nth-child(3n + 1)”)

  $(”div span:first-child”) 匹配父元素的第1个子元素

  $(”div span:last-child”) 匹配父元素的最后1个子元素

  $(”div button:only-child”) 匹配父元素的唯一1个子元素

  表单元素选择器

  $(”:input”) 匹配所有的表单输入元素,包括所有类型的input, textarea, select 和 button

  $(”:text”) 匹配所有类型为text的input元素

  $(”:password”) 匹配所有类型为password的input元素

  $(”:radio”) 匹配所有类型为radio的input元素

  $(”:checkbox”) 匹配所有类型为checkbox的input元素

  $(”:submit”) 匹配所有类型为submit的input元素

  $(”:image”) 匹配所有类型为image的input元素

  $(”:reset”) 匹配所有类型为reset的input元素

  $(”:button”) 匹配所有类型为button的input元素

  $(”:file”) 匹配所有类型为file的input元素

  $(”:hidden”) 匹配所有类型为hidden的input元素或表单的隐藏域

  表单元素过滤选择器

  $(”:enabled”) 匹配所有可操作的表单元素

  $(”:disabled”) 匹配所有不可操作的表单元素

  $(”:checked”) 匹配所有已点选的元素

  $(”select option:selected”) 匹配所有已选择的元素

  JQuery CSS 方法说明

  css( name ) 访问第一个匹配元素的样式属性。

  css( properties ) 把一个”名/值对”对象设置为所有匹配元素的样式属性。

  $(”p”).hover(function () {

  $(this).css({ backgroundColor:”yellow”,fontWeight:”bolder” });

  }, function () {

  var cssObj = {

  backgroundColor: “#ddd”,

  fontWeight: “”,

  color: “rgb(0,40,244)”

  }

  $(this).css(cssObj);

  });

  css( name, value ) 在所有匹配的元素中,设置一个样式属性的值。

  offset( ) 取得匹配的第一个元素相对于当前可视窗口的位置。返回的对象有2个属性,

  top和left,属性值为整数。这个函数只能用于可见元素。

  var p = $(”p:last”);

  var offset = p.offset();

  p.html( “left: ” + offset.left + “,top: ” + offset.top );

  width( ) 取得当前第一匹配的元素的宽度值,

  width( val ) 为每个匹配的元素设置指定的宽度值。

  height( ) 取得当前第一匹配的元素的高度值,

  height( val ) 为每个匹配的元素设置指定的高度值。

  JQuery Utilities 方法说明

  jQuery.browser

  .msie 表示ie

  jQuery.browser.version 读取用户浏览器的版本信息

  jQuery.boxModel 检测用户浏览器针对当前页的显示是否基于w3c CSS的盒模型

  jQuery.isFunction( obj ) 检测传递的参数是否为function

  function stub() { }

  var objs = [

  function () {},

  { x:15, y:20 },

  null,

  stub,

  “function”

  ];

  jQuery.each(objs, function (i) {

  var isFunc = jQuery.isFunction(objs[i]);

  $(”span:eq( ” + i + “)”).text(isFunc);

  });

  jQuery.trim( str ) 清除字符串两端的空格,使用正则表达式来清除给定字符两端的空格

  jQuery.each( object, callback ) 一个通用的迭代器,可以用来无缝迭代对象和数组

  jQuery.extend( target, object1, [objectN] ) 扩展一个对象,修改原来的对象并返回,这是一个强大的实现继承的

  工具,这种继承是采用传值的方法来实现的,而不是JavaScript中的

  原型链方式。

  合并settings和options对象,返回修改后的settings对象

  var settings = { validate: false, limit: 5, name: “foo”};

  var options = { validate: true, name: “bar”};

  jQuery.extend(settings, options);

  合并defaults和options对象,defaults对象并没有被修改。options对象中的值

  代替了defaults对象的值传递给了empty。

  var empty = {}

  var defaults = { validate: false, limit: 5, name: “foo”};

  var options = { validate: true, name: “bar”};

  var settings = $.extend(empty, defaults, options);

  jQuery.grep( array, callback, [invert] ) 通过一个筛选函数来去除数组中的项

  $.grep( [0,1,2], function(n,i){

  return n > 0;

  });

  jQuery.makeArray( obj ) 将一个类似数组的对象转化为一个真正的数组

  将选取的div元素集合转化为一个数组

  var arr = jQuery.makeArray(document.getElementsByTagName(”div”));

  arr.reverse(); // use an Array method on list of dom elements

  $(arr).appendTo(document.body);

  jQuery.map( array, callback ) 使用某个方法修改一个数组中的项,然后返回一个新的数组

  jQuery.inArray( value, array ) 返回value在数组中的位置,如果没有找到,则返回-1

  jQuery.unique( array ) 删除数组中的所有重复元素,返回整理后的数组

 

jQuery常用技巧