教程:jQuery使用手册--核心篇(Core)

jQuery使用手册--核心篇(Core)
翻译整理:Young.J
官方网站:http://jquery.com
    jQuery是一款同prototype一样优秀js开发库类,特 别是对css和XPath的支持,使我们写js变得更加方便!
如果你不是个js高手又想写出优 秀的js效果,jQuery可以帮你达到目的!
下 载地址:Starterkit (http://jquery.bassistance.de/jquery-starterkit.zip
          jQuery Downloads (http://jquery.com/src/
下 载完成后先加载到文档中,然后我们来看个简单的例子!

复制代码  


1. <script language=/"javascript/" type=/"text/javascript/">   
2.     $(document).ready(function(){
3.         $(/"a/").click(function(){
4.         alert(/"Hello world!/");
5.    });
6. });
7. <script>

    上 边的效果是点击文档中所有a标签时将弹出对话框,$("a") 是一个jQuery选择器,$本身表示一个jQuery类,
所有$()是构造一个 jQuery对象,click()是这个对象的方法,同理$(document)也是一个jQuery对象,ready(fn)是$(document) 的方法,表示当document全部下载完毕时执行函数。
    在进行下面内容之前我还要说明一点$("p")和$("#p")的区 别,$("p")表示取所有p标签(<p></p>)的元素,
$("#p")表示取id为"p" (<span  id="p"></span>)的元素.
我将从以下几个内容来讲解jQuery的使用:
1:核 心部分
2:DOM操作
3:css操作
4:javascript处理
5:动态效果
6:event事件
7:ajax 支持
8:插件程序
一:核心部分
$(expr)
说 明:该函数可以通过css选择器,Xpath或html代码来匹配目标元素,所有的jQuery操作都以此为基础
参数:expr:字符串,一个查 询表达式或一段html字符串
例子:
未执行jQuery前:

复制代码  


1. <p>one</p>
2. <div>
3.       <p>two</p>
4. </div>
5.     <p>three</p> 
6.     <a href=/"#/" id=/"test/" onClick=/"jq()/" >jQuery</a>



复制代码  


1. jQuery代码及功能:
2. function jq(){  
3.     alert($(/"div > p/").html());  
4. }

运 行:当点击id为test的元素时,弹出对话框文字为two,即div标签下p元素的内容

复制代码  


1. function jq(){
2.     $(/"<div><p>Hello</p></div>/").appendTo(/"body/");
3. }

运 行:当点击id为test的元素时,向body中添加“<div><p>Hello</p>< /div>”
$(elem)
说明:限制jQuery作用于一个特定的dom元素,这个函数也接受xml文档和windows对象
参 数: elem:通过jQuery对象压缩的DOM元素
例子:
未执行jQuery前:

复制代码  


1. <p>one</p>
2.   <div>
3.      <p>two</p>
4.   </div><p>three</p>
5. <a href=/"#/" id=/"test/" onClick=/"jq()/">jQuery</a>


jQuery 代码及功能:

复制代码  


1. function jq(){
2.     alert($(document).find(/"div > p/").html());
3. }


运 行:当点击id为test的元素时,弹出对话框文字为two,即div标签下p元素的内容

复制代码  


1. function jq(){
2.    $(document.body).css(/"background/",/"black/");
3. }

运 行:当点击id为test的元素时,背景色变成黑色
$(elems)
说 明:限制jQuery作用于一组特定的DOM元素
参数: elem:一组通过jQuery对象压缩的DOM元素
例子:
未执行 jQuery前:

复制代码  


1. <form id=/"form1/">
2.       <input type=/"text/" name=/"textfield/">
3.       <input type=/"submit/" name=/"Submit/" value=/"提交/">
4. </form>
5. <a href=/"#/" id=/"test/" onClick=/"jq()/">jQuery</a>


jQuery 代码及功能:

复制代码  


1. function jq(){ 
2.    $(form1.elements ).hide(); 
3. }


运 行:当点击id为test的元素时,隐藏form1表单中的所有元素。
$(fn)
说 明:$(document).ready()的一个速记方式,当文档全部载入时执行函数。可以有多个$(fn)当文档载入时,同时执行所有函数!
参 数:fn (Function):当文档载入时执行的函数!
例子:

复制代码  


1. $(function(){
2.     $(document.body).css(/"background/",/"black/");
3. })


运 行:当文档载入时背景变成黑色,相当于onLoad。

$(obj)
说 明:复制一个jQuery对象,
参数:obj (jQuery): 要复制的jQuery对象
例子:
未执行jQuery前:

复制代码  


1. <p>one</p>
2. <div>
3.    <p>two</p>
4. </div>
5. <p>three</p>
6. <a href=/"#/" id=/"test/" onClick=/"jq()/">jQuery</a>


jQuery 代码及功能:

复制代码  


1. function jq(){
2.     var f = $(/"div/"); 
3.     alert($(f).find(/"p/").html()) 
4. }


运 行:当点击id为test的元素时,弹出对话框文字为two,即div标签下p元素的内容。

each(fn)
说明:将函数作用于所有匹配的对象上
参数:fn (Function): 需要执行的函数
例子:
未执行jQuery前:

复制代码  


1. <img src=/"1.jpg/"/>
2. <img src=/"1.jpg/"/>
3. <a href=/"#/" id=/"test/" onClick=/"jq()/">jQuery</a>



复制代码  


1. jQuery代码及功能: 
2. function jq(){
3.    $(/"img/").each(function(){ 
4.         this.src = /"2.jpg/"; });
5. }

运 行:当点击id为test的元素时,img标签的src都变成了2.jpg。

eq(pos)
说 明:减少匹配对象到一个单独得dom元素
参数:pos (Number): 期望限制的索引,从0 开始
例子:
未执行 jQuery前:

复制代码  


1. <p>This is just a test.</p>
2. <p>So is this</p>
3. <a href=/"#/" id=/"test/" onClick=/"jq()/">jQuery</a>


jQuery 代码及功能:

复制代码  


1. function jq(){
2.     alert($(/"p/").eq(1).html())
3. }

运 行:当点击id为test的元素时,alert对话框显示:So is this,即第二个<p>标签的内容

get() get(num)
说明:获取匹配元素,get(num)返回匹配 元素中的某一个元素
参数:get (Number): 期望限制的索引,从0 开始
例子:
未执行jQuery前:

复制代码  


1. <p>This is just a test.</p>
2. <p>So is this</p>
3. <a href=/"#/" id=/"test/" onClick=/"jq()/">jQuery</a>


jQuery 代码及功能:

复制代码  


1. function jq(){
2.     alert($(/"p/").get(1).innerHTML);
3. }


    运 行:当点击id为test的元素时,alert对话框显示:So is this,即第二个<p>标签的内容
注意get和eq的区 别,eq返回的是jQuery对象,get返回的是所匹配的dom对象,所有取$("p").eq(1)对象的内容用jQuery方法html(),
而 取$("p").get(1)的内容用innerHTML
index(obj)
说 明:返回对象索引
参数:obj (Object): 要查找的对象
例子:
未执行jQuery前:

复制代码  


1. <div id=/"test1/"></div>
2. <div id=/"test2/"></div>
3. <a href=/"#/" id=/"test/" onClick=/"jq()/">jQuery</a>


jQuery 代码及功能:

复制代码  


1. function jq(){
2.     alert($(/"div/").index(document.getElementById('test1')));
3.     alert($(/"div/").index(document.getElementById('test2')));
4. }


运 行:当点击id为test的元素时,两次弹出alert对话框分别显示0,1
size()   Length
说明:当前匹配对象的数量,两者等价
例子:
未执行jQuery前:

复制代码  


1. <img src=/"test1.jpg/"/>
2. <img src=/"test2.jpg/"/>
3. <a href=/"#/" id=/"test/" onClick=/"jq()/">jQuery</a>

jQuery 代码及功能:

复制代码  


1. function jq(){
2.     alert($(/"img/").length);
3. }

运 行:当点击id为test的元素时,弹出alert对话框显示2,表示找到两个匹配对象