jQuery 教程

jQuery 教程

· jQuery 教程

· jQuery 简介

· jQuery 语法

· jQuery 选择器

· jQuery 事件

· jQuery 效果

· jQuery Callback

· jQuery HTML

· jQuery CSS

· jQuery AJAX

· jQuery 实例

 jQuery 参考手册

· jQuery 参考手册

· jQuery 选择器

· jQuery 事件

· jQuery 效果

· jQuery 文档操作

· jQuery 属性

· jQuery CSS

· jQuery Ajax

· jQuery 遍历

· jQuery 数据存储

· jQuery 队列控制

· jQuery 核心

一:JQuery 

1. 介绍

jQuery 是一个 JavaScript 库。

jQuery 极大地简化了 JavaScript 编程。

jQuery 很容易学习。

每一章中用到的实例

<html>

<head>

<script type="text/javascript" src="jquery.js"></script>

<script type="text/javascript">

$(document).ready(function(){

  $("p").click(function(){

  $(this).hide();

  });

});

</script>

</head>

<body>

<p>If you click on me, I will disappear.</p>

</body>

</html> 

TIY

通过点击 "TIY" 按钮来看看它是如何运行的。

您将学到什么

在本教程中,您将通过文字以及许多在线实例,学到如何通过使用 jQuery 网页应用 JavaScript 效果。

jQuery 是一个写的更少,但做的更多的轻量级 JavaScript 库。

基本上,您将学习到如何选取 HTML 元素,以及如何对它们执行类似隐藏、移动以及操作其内容等任务。

您需要具备的基础知识

在您开始学习 jQuery 之前,您应该对以下知识有基本的了解:

· HTML

· CSS

· JavaScript

如果您需要首先学习这些科目,请在我们的 首页 查找这些教程。

jQuery 实例

通过实例来学习!在 W3School,您将找到很多能够编辑并测试的 jQuery 实例。

jQuery 实例

jQuery 参考手册

在 W3School,您将找到包含所有 jQuery 对象和函数的完整参考手册。

jQuery 参考手册

2.jQuery 简介

jQuery 库可以通过一行简单的标记被添加到网页中。

jQuery 库 特性

jQuery 是一个 JavaScript 函数库。

jQuery 库包含以下特性:

· HTML 元素选取

· HTML 元素操作

· CSS 操作

· HTML 事件函数

· JavaScript 特效和动画

· HTML DOM 遍历和修改

· AJAX

· Utilities

向您的页面添加 jQuery 

jQuery 库位于单个的 JavaScript 文件中,其中包含所有 jQuery 函数。

可以通过下面的标记把 jQuery 添加到网页中:

<head>

<script type="text/javascript" src="jquery.js"></script>

</head>

请注意,<script> 标签应该位于页面的 <head> 部分。

基础 jQuery 实例

下面的例子演示了 jQuery 的 hide() 函数,隐藏了 HTML 文档中所有的 <p> 元素。

实例

<html>

<head>

<script type="text/javascript" src="jquery.js"></script>

<script type="text/javascript">

$(document).ready(function(){

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

$("p").hide();

});

});

</script>

</head>

<body>

<h2>This is a heading</h2>

<p>This is a paragraph.</p>

<p>This is another paragraph.</p>

<button type="button">Click me</button>

</body>

</html>

TIY

下载 jQuery

存在两份 jQuery 拷贝可供下载,一是缩小版(由 Google Closure Compiler),另一个是未压缩版(供 debugging 或 reading)。

两份拷贝均可以从 jQuery.com 下载(左键点击然后另存为):

· jQuery minfied (23K)

· jQuery regular (154K)

库的替代

Google 和 Microsoft 对 jQuery 的支持都很好。

如果您不愿意在自己的计算机上存放 jQuery 库,那么可以从 Google or Microsoft 加载 CDN jQuery 核心文件。

使用 Google 的 CDN

<head>

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs

/jquery/1.4.0/jquery.min.js"></script>

</head>

使用 Microsoft 的 CDN

<head>

<script type="text/javascript" src="http://ajax.microsoft.com/ajax/jquery

/jquery-1.4.min.js"></script>

</head>

3.jQuery 语法

通过 jQuery,您可以选取(查询,query) HTML 元素,并对它们执行操作actions)。

jQuery 语法实例

$(this).hide()

演示 jQuery hide() 函数,隐藏当前的 HTML 元素。

$("#test").hide()

演示 jQuery hide() 函数,隐藏 id="test" 的元素。

$("p").hide()

演示 jQuery hide() 函数,隐藏所有 <p> 元素。

$(".test").hide()

演示 jQuery hide() 函数,隐藏所有 class="test" 的元素。

jQuery 语法

jQuery 语法是为 HTML 元素的选取编制,可以对元素执行某些操作。

基础语法是:$(selector).action()

· 美元符号定义 jQuery

· 选择符(selector查询查找” HTML 元素

· jQuery action() 执行对元素的操作

实例

$(this).hide() - 隐藏当前元素

$("p").hide() - 隐藏所有段落

$("p.test").hide() - 隐藏所有 class="test" 的段落

$("#test").hide() - 隐藏所有 id="test" 的元素

提示:jQuery 使用的语法是 XPath 与 CSS 选择器语法的组合。在本教程接下来的章节,您将学习到更多有关选择器的语法。

文档就绪函数

您也许已经注意到在我们的实例中的所有 jQuery 函数位于一个 document ready 函数中:

$(document).ready(function(){

--- jQuery functions go here ----

});

这是为了防止文档在完全加载(就绪)之前运行 jQuery 代码。

下面是两种假如文档完全加载之前运行函数的话,操作失败的情况:

· 试图隐藏一个不存在的元素。

· 获得未完全加载的图像的大小。

4.jQuery 选择器

选择器允许您对元素组或单个元素进行操作。

jQuery 选择器

在前面的章节中,我们展示了一些有关如何选取 HTML 元素的实例。

关键点是学习 jQuery 选择器是如何准确地选取您希望应用效果的元素。

jQuery 元素选择器和属性选择器允许您通过标签名、属性名或内容对 HTML 元素进行选择。

选择器允许您对 HTML 元素组或单个元素进行操作。

在 HTML DOM 术语中:

选择器允许您对 DOM 元素组或单个 DOM 节点进行操作。

jQuery 元素选择器

jQuery 使用 CSS 选择器来选取 HTML 元素。

$("p") 选取 <p> 元素。

$("p.intro") 选取所有 class="intro" 的 <p> 元素。

$("p#demo") 选取 id="demo" 的第一个 <p> 元素。

jQuery 属性选择器

jQuery 使用 XPath 表达式来选择带有给定属性的元素。

$("[href]") 选取所有带有 href 属性的元素。

$("[href='#']") 选取所有带有 href 值等于 "#" 的元素。

$("[href!='#']") 选取所有带有 href 值不等于 "#" 的元素。

$("[href$='.jpg']") 选取所有 href 值以 ".jpg" 结尾的元素。

jQuery CSS 选择器

jQuery CSS 选择器可用于改变 HTML 元素的 CSS 属性。

下面的例子把所有 元素的背景颜色更改为红色:

实例

$("p").css("background-color","red");

TIY

更多的实例

语法

描述

$(this)

当前 HTML 元素

$("p")

所有 <p> 元素

$("p.intro")

所有 class="intro" 的 <p> 元素

$(".intro")

所有 class="intro" 的元素

$("#intro")

id="intro" 的第一个元素

$("ul li:first")

每个 <ul> 的第一个 <li> 元素

$("[href$='.jpg']")

所有带有以 ".jpg" 结尾的 href 属性的属性

$("div#intro .head")

id="intro" 的 <div> 元素中的所有 class="head" 的元素

如需完整的参考手册,请访问我们的 jQuery 选择器参考手册

5.jQuery 事件

jQuery 是为事件处理特别设计的。

jQuery 事件函数

jQuery 事件处理函数是 jQuery 中的核心函数。

事件处理函数是当 HTML 中发生事件时自动被调用的函数。由事件event触发triggered)是经常被用到的术语。

在您 <head> 

由于 jQuery 是为事件处理特别设计的,通常是把 jQuery 代码置于网页 <head> 部分的事件处理函数中:

实例

<html>

<head>

<script type="text/javascript" src="jquery.js"></script>

<script type="text/javascript">

$(document).ready(function(){

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

  $("p").hide();

  });

});

</script>

</head>

<body>

<h2>This is a heading</h2>

<p>This is a paragraph.</p>

<p>This is another paragraph.</p>

<button type="button">Click me</button>

</body>

</html>

TIY

在上面的例子中,定义了一个处理 HTML 按钮的点击事件的 click 函数:

$("button").click(function() {..some code... } )

click 函数内部的代码隐藏所有 <p> 元素:

$("p").hide();

所有事件函数都在文档自身的事件处理器内部进行定义:

$(document).ready(function() {..some code...} )

单独文件中的函数

如果您的网站包含许多页面,并且您希望您的 jQuery 函数易于维护,那么请把您的 jQuery 函数放到独立的 .js 文件中。

当我们在教程中演示 jQuery 时,会将函数直接添加到 <head> 部分中。不过,把它们放到一个单独的文件中会更好,就像这样(通过 src 属性来引用文件):

实例

<head>

<script type="text/javascript" src="jquery.js"></script>

<script type="text/javascript" src="my_jquery_functions.js"></script>

</head>

jQuery 名称冲突

jQuery 使用 符号作为 jQuery 的简介方式。

某些其他 JavaScript 库中的函数(比如 Prototype)同样使用 符号。

jQuery 使用名为 noConflict() 的方法来解决该问题。

var jq=jQuery.noConflict(),帮助您使用自己的名称(比如 jq)来代替 符号。

TIY

结论

由于 jQuery 是为处理 HTML 事件而特别设计的,那么当您遵循以下原则时,您的代码会更恰当且更易维护:

· 把所有 jQuery 代码置于事件处理函数中

· 把所有事件处理函数置于文档就绪事件处理器中

· 把 jQuery 代码置于单独的 .js 文件中

· 如果存在名称冲突,则重命名 jQuery 

jQuery 事件

下面是 jQuery 中事件函数的一些例子:

Event 函数

绑定函数至

$(document).ready(function)

文档的就绪事件

(当 HTML 文档就绪可用)

$(selector).click(function)

被选元素的点击事件

$(selector).dblclick(function)

被选元素的双击事件

$(selector).focus(function)

被选元素的获得焦点事件

$(selector).mouseover(function)

被选元素的鼠标悬停事件

(selector) jQuery 元素选择器

如需完整的参考手册,请访问我们的 jQuery 事件参考手册

6.jQuery 效果

jQuery 是为事件处理特别设计的。

jQuery 事件函数

隐藏、显示、切换、滑动 以及动画。WOW!

Click Here to Show/Hide Panel

实例

jQuery hide()

演示简单的 jQuery hide() 函数。

jQuery hide()

另一个 hide() 演示。如何隐藏部分文本。

jQuery slideToggle()

演示简单的 slide panel 效果。

jQuery fadeTo()

演示简单的 jQuery fadeTo() 函数。

jQuery animate()

演示简单的 jQuery animate() 函数。

jQuery 隐藏和显示

通过 hide() 和 show() 两个函数,jQuery 支持对 HTML 元素的隐藏和显示:

实例

$("#hide").click(function(){

$("p").hide();

});

$("#show").click(function(){

$("p").show();

});

TIY

hide() 和 show() 都可以设置两个可选参数:speed 和 callback

语法:

$(selector).hide(speed,callback)

$(selector).show(speed,callback)

callback 参数是在 hide 或 show 函数完成之后被执行的函数名称。您将在本教程下面的章节学习更多有关 callback 参数的知识。

speed 参数可以设置这些值:"slow", "fast", "normal" 或 milliseconds

实例

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

$("p").hide(1000);

});

TIY

jQuery 切换

jQuery toggle() 函数使用 show() 或 hide() 函数来切换 HTML 元素的可见状态。

隐藏显示的元素,显示隐藏的元素。

语法:

$(selector).toggle(speed,callback)

speed 参数可以设置这些值:"slow", "fast", "normal" 或 毫秒。

实例

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

$("p").toggle();

});

TIY

callback 参数是在 hide 或 show 函数完成之后被执行的函数名称。您将在本教程下面的章节学习更多有关 callback 参数的知识。

jQuery 滑动函数 - slideDown, slideUp, slideToggle

jQuery 拥有以下滑动函数:

$(selector).slideDown(speed,callback)

$(selector).slideUp(speed,callback)

$(selector).slideToggle(speed,callback)

speed 参数可以设置这些值:"slow", "fast", "normal" 或 毫秒。

callback 参数是在 hide 或 show 函数完成之后被执行的函数名称。您将在本教程下面的章节学习更多有关 callback 参数的知识。

slideDown() 实例

$(".flip").click(function(){

$(".panel").slideDown();

});

TIY

slideUp() 实例

$(".flip").click(function(){

$(".panel").slideUp()

})

TIY

slideToggle() 实例

$(".flip").click(function(){

$(".panel").slideToggle();

});

TIY

jQuery Fade 函数 - fadeIn(), fadeOut(), fadeTo()

jQuery 拥有以下 fade 函数:

$(selector).fadeIn(speed,callback)

$(selector).fadeOut(speed,callback)

$(selector).fadeTo(speed,opacity,callback)

speed 参数可以设置这些值:"slow", "fast", "normal" 或 毫秒。

fadeTo() 函数中的 opacity 参数规定减弱到给定的不透明度。

callback 参数是在 hide 或 show 函数完成之后被执行的函数名称。您将在本教程下面的章节学习更多有关 callback 参数的知识。

fadeTo() 实例

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

$("div").fadeTo("slow",0.25);

});

TIY

fadeOut() 实例

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

$("div").fadeOut(4000);

});

TIY

jQuery 自定义动画

jQuery 函数创建自定义动画的语法:

$(selector).animate({params},[duration],[easing],[callback])

关键的参数是 params。它定义了产生动画的属性。可以同时设置多个此类属性:

animate({width:"70%",opacity:0.4,marginLeft:"0.6in",fontSize:"3em"});

第二个参数是 duration。它定义用来应用于动画的时间。它设置的值是:"slow", "fast", "normal" 或 毫秒。

实例 1

<script type="text/javascript">

$(document).ready(function(){

$("#start").click(function(){

$("#box").animate({height:300},"slow");

$("#box").animate({width:300},"slow");

$("#box").animate({height:100},"slow");

$("#box").animate({width:100},"slow");

});

});

</script> 

TIY

实例 2

<script type="text/javascript">

$(document).ready(function(){

$("#start").click(function(){

$("#box").animate({left:"100px"},"slow");

$("#box").animate({fontSize:"3em"},"slow");

});

});

</script> 

TIY

HTML 元素默认是静态定位,且无法移动。

如需使元素可以移动,请把 CSS 的 position 设置为 relative 或 absolute

jQuery 效果 来自本页

函数

描述

$(selector).hide()

隐藏被选元素

$(selector).show()

显示被选元素

$(selector).toggle()

切换(在隐藏与显示之间)被选元素

$(selector).slideDown()

向下滑动(显示)被选元素

$(selector).slideUp()

向上滑动(隐藏)被选元素

$(selector).slideToggle()

对被选元素切换向上滑动和向下滑动

$(selector).fadeIn()

淡入被选元素

$(selector).fadeOut()

淡出被选元素

$(selector).fadeTo()

把被选元素淡出为给定的不透明度

$(selector).animate()

对被选元素执行自定义动画

如需完整的参考手册,请访问我们的 jQuery Effect 参考手册

7.jQuery Callback 函数

动画创造了对 callback 函数的需求。

Because animations take time. We have to wait before we can execute the next instruction.

The callback function is called after the animation is 100% finished.

Click Here to Show/Hide Panel

jQuery 动画的问题

许多 jQuery 函数涉及动画。这些函数也许会将 speed 或 duration 作为可选参数。

例子:$("p").hide("slow")

speed 或 duration 参数可以设置许多不同的值,比如 "slow", "fast", "normal" 或毫秒。

实例

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

$("p").hide(1000);

});

TIY

由于 JavaScript 语句(指令)是逐一执行的 按照次序,动画之后的语句可能会产生错误或页面冲突,因为动画还没有完成。

为了避免这个情况,您可以以参数的形式添加 Callback 函数。

jQuery Callback 函数

当动画 100% 完成后,即调用 Callback 函数。

典型的语法:

$(selector).hide(speed,callback)

callback 参数是一个在 hide 操作完成后被执行的函数。

错误(没有 callback

$("p").hide(1000);

alert("The paragraph is now hidden");

TIY

正确(有 callback

$("p").hide(1000,function(){

alert("The paragraph is now hidden");

});

TIY

结论:如果您希望在一个涉及动画的函数之后来执行语句,请使用 callback 函数。

8.jQuery HTML 操作

jQuery 包含很多供改变和操作 HTML 的强大函数。

改变 HTML 内容

语法

$(selector).html(content)

html() 函数改变所匹配的 HTML 元素的内容(innerHTML)。

实例

$("p").html("W3School");

TIY

添加 HTML 内容

语法

$(selector).append(content)

append() 函数向所匹配的 HTML 元素内部追加内容。

语法

$(selector).prepend(content)

prepend() 函数向所匹配的 HTML 元素内部预置(Prepend)内容。

实例

$("p").append(" W3School");

TIY

语法

$(selector).after(content)

after() 函数在所有匹配的元素之后插入 HTML 内容。

语法

$(selector).before(content)

before() 函数在所有匹配的元素之前插入 HTML 内容。

实例

$("p").after(" W3School.");

TIY

jQuery HTML 操作 来自本页

函数

描述

$(selector).html(content)

改变被选元素的(内部)HTML

$(selector).append(content)

向被选元素的(内部)HTML 追加内容

$(selector).prepend(content)

向被选元素的(内部)HTML “预置Prepend)内容

$(selector).after(content)

在被选元素之后添加 HTML

$(selector).before(content)

在被选元素之前添加 HTML

(selector) jQuery 元素选择器语法

如需完整的参考手册,请访问我们的 jQuery HTML 操作参考手册

9.jQuery CSS 函数

jQuery CSS 操作

jQuery 拥有三种供 CSS 操作的重要函数:

· $(selector).css(name,value)

· $(selector).css({properties})

· $(selector).css(name)

CSS 操作实例

函数 css(name,value) 为所有匹配元素的给定 CSS 属性设置值:

实例

$(selector).css(name,value)

$("p").css("background-color","yellow");

TIY

函数 css({properties}) 同时为所有匹配元素的一系列 CSS 属性设置值:

实例

$(selector).css({properties})

$("p").css({"background-color":"yellow","font-size":"200%"});

TIY

函数 css(name) 返回指定的 CSS 属性的值:

实例

$(selector).css(name)

$(this).css("background-color");

TIY

jQuery Size 操作

jQuery 拥有两种供尺寸操作的重要函数:

· $(selector).height(value)

· $(selector).width(value)

Size 操作实例

函数 height(value) 设置所有匹配元素的高度:

实例

$(selector).height(value)

$("#id100").height("200px");

TIY

函数 width(value) 设置所有匹配元素的宽度:

实例

$(selector).width(value)

$("#id200").width("300px");

TIY

jQuery CSS 函数 来自本页

CSS 属性

描述

$(selector).css(name,value)

为匹配元素设置样式属性的值

$(selector).css({properties})

为匹配元素设置多个样式属性

$(selector).css(name)

获得第一个匹配元素的样式属性值

$(selector).height(value)

设置匹配元素的高度

$(selector).width(value)

设置匹配元素的宽度

(selector) jQuery 元素选择器语法

如需完整的参考手册,请访问我们的 jQuery CSS 函数参考手册

10.jQuery AJAX 函数

jQuery 拥有供 AJAX 开发的丰富函数(方法)库。

jQuery AJAX 实例

AJAX is not a programming language.

It is just a technique for creating better and more interactive web applications.

Change Content

TIY

上面的例子摘自我们的 AJAX 教程,但使用 jQuery 进行了修改。

什么是 AJAX

AJAX = Asynchronous JavaScript and XML.

AJAX 是一种创建快速动态网页的技术。

AJAX 通过在后台与服务器交换少量数据的方式,允许网页进行异步更新。这意味着有可能在不重载整个页面的情况下,对网页的一部分进行更新。

您可以在我们的 AJAX 教程 中学习更多有关 AJAX 的知识。

AJAX 和 jQuery

jQuery 提供了供 AJAX 开发的丰富函数(方法)库。

通过 jQuery AJAX,使用 HTTP Get 和 HTTP Post,您都可以从远程服务器请求 TXTHTMLXML 或 JSON

而且您可以直接把远程数据载入网页的被选 HTML 元素中!

写的更少,做的更多

jQuery 的 load 函数是一种简单的(但很强大的)AJAX 函数。它的语法如下:

$(selector).load(url,data,callback)

请使用选择器来定义要改变的 HTML 元素,使用 url 参数来指定您的数据的 web 地址。

TIY

只有当您希望向服务器发送数据,才需要使用 data 参数。只有当您需要在完毕之后触发一个函数时,您才需要使用 callback 参数。

Low Level AJAX

$.ajax(options) 是低层级 AJAX 函数的语法。

$.ajax 提供了比高层级函数更多的功能,但是同时也更难使用。

option 参数设置的是 name|value 对,定义 url 数据、密码、数据类型、过滤器、字符集、超时以及错误函数。

TIY

jQuery AJAX 请求

请求

描述

$(selector).load(url,data,callback)

把远程数据加载到被选的元素中

$.ajax(options)

把远程数据加载到 XMLHttpRequest 对象中

$.get(url,data,callback,type)

使用 HTTP GET 来加载远程数据

$.post(url,data,callback,type)

使用 HTTP POST 来加载远程数据

$.getJSON(url,data,callback)

使用 HTTP GET 来加载远程 JSON 数据

$.getScript(url,callback)

加载并执行远程的 JavaScript 文件

(selector) jQuery 元素选择器语法

(url) 被加载的数据的 URL(地址)

(data) 发送到服务器的数据的键/值对象

(callback) 当数据被加载时,所执行的函数

(type) 被返回的数据的类型 (html,xml,json,jasonp,script,text)

(options) 完整 AJAX 请求的所有键/值对选项

参考手册

如需更多有关 jQuery AJAX 函数的信息,请访问我们的 jQuery AJAX 参考手册

11.jQuery 实例

通过实例增进 jQuery 技能!

jQuery 语法实例

$(this).hide()

演示 jQuery 的 hide() 函数,隐藏当前的 HTML 元素。

$("p").hide()

演示 jQuery 的 hide() 函数,隐藏所有 <p> 元素。

$(".test").hide()

演示 jQuery 的 hide() 函数,隐藏所有 class="test" 的元素。

$("#test").hide()

演示 jQuery 的 hide() 函数,隐藏 id="test" 的元素。

例子解释

Hiding - Sliding- Fading

jQuery fadeOut()

演示简单的 jQuery fadeout() 函数。

jQuery hide()

演示简单的 jQuery hide() 函数。

Hide explanations

演示如何隐藏部分文本。

Slide panel

演示简单的 Slide Panel 效果。

jQuery animate()

演示简单的 jQuery animate() 函数。

例子解释

HTML 操作

改变 HTML 元素的内容

向 HTML 元素追加内容

在 HTML 元素之后追加内容

例子解释

CSS 操作

改变 HTML 元素的 CSS 属性

改变多个 CSS 属性

获得元素的 CSS 属性

例子解释

AJAX 和 jQuery

使用 $(selector).load(url) 来改变 HTML 内容

<html>

<head>

<script type="text/javascript" src="/jquery/jquery.js"></script>

<script type="text/javascript">

$(document).ready(function(){

  $("#b01").click(function(){

  $('#myDiv').load('/jquery/test1.txt');

  });

});

</script>

</head>

<body>

<div id="myDiv"><h2>Let AJAX change this text</h2></div>

<button id="b01" type="button">Change Content</button>

</body>

</html>

使用 $.ajax(options) 来改变 HTML 内容

<html>

<head>

<script type="text/javascript" src="/jquery/jquery.js"></script>

<script type="text/javascript">

$(document).ready(function(){

  $("#b01").click(function(){

  htmlobj=$.ajax({url:"/jquery/test1.txt",async:false});

  $("#myDiv").html(htmlobj.responseText);

  });

});

</script>

</head>

<body>

<div id="myDiv"><h2>Let AJAX change this text</h2></div>

<button id="b01" type="button">Change Content</button>

</body>

</html>

例子解释

二:jQuery 参考手册

jQuery 参考手册

在 W3School,您将找到包含所有 jQuery 对象和函数的完整参考手册:

· 选择器

· 事件

· 效果

· 文档操作

· CSS 操作

· AJAX 操作

· 遍历

· 数据存储

· 队列控制

· 核心

12.jQuery 参考手册 - 选择器

jQuery 选择器

选择器

实例

选取

*

$("*")

所有元素

#id

$("#lastname")

id=lastname 的元素

.class

$(".intro")

所有 class="intro" 的元素

element

$("p")

所有 <p> 元素

.class.class

$(".intro.demo")

所有 class=intro 且 class=demo 的元素

 

 

 

:first

$("p:first")

第一个 <p> 元素

:last

$("p:last")

最后一个 <p> 元素

:even

$("tr:even")

所有偶数 <tr> 元素

:odd

$("tr:odd")

所有奇数 <tr> 元素

 

 

 

:eq(index)

$("ul li:eq(3)")

列表中的第四个元素(index 从 开始)

:gt(no)

$("ul li:gt(3)")

列出 index 大于 的元素

:lt(no)

$("ul li:lt(3)")

列出 index 小于 的元素

:not(selector)

$("input:not(:empty)")

所有不为空的 input 元素

 

 

 

:header

$(":header")

所有标题元素 <h1><h2>...

:animated

 

所有动画元素

 

 

 

:contains(text)

$(":contains('W3School')")

包含文本的所有元素

:empty

$(":empty")

无子(元素)节点的所有元素

:hidden

$("p:hidden")

所有隐藏的 <p> 元素

:visible

$("table:visible")

所有可见的表格

 

 

 

s1,s2,s3

$("th,td,.intro")

所有带有匹配选择的元素

 

 

 

[attribute]

$("[href]")

所有带有 href 属性的元素

[attribute=value]

$("[href='#']")

所有 href 属性的值等于 "#" 的元素

[attribute!=value]

$("[href!='#']")

所有 href 属性的值不等于 "#" 的元素

[attribute$=value]

$("[href$='.jpg']")

所有 href 属性的值包含 ".jpg" 的元素

 

 

 

:input

$(":input")

所有 <input> 元素

:text

$(":text")

所有 type="text" 的 <input> 元素

:password

$(":password")

所有 type="password" 的 <input> 元素

:radio

$(":radio")

所有 type="radio" 的 <input> 元素

:checkbox

$(":checkbox")

所有 type="checkbox" 的 <input> 元素

:submit

$(":submit")

所有 type="submit" 的 <input> 元素

:reset

$(":reset")

所有 type="reset" 的 <input> 元素

:button

$(":button")

所有 type="button" 的 <input> 元素

:image

$(":image")

所有 type="image" 的 <input> 元素

:file

$(":file")

所有 type="file" 的 <input> 元素

 

 

 

:enabled

$(":enabled")

所有激活的 input 元素

:disabled

$(":disabled")

所有禁用的 input 元素

:selected

$(":selected")

所有被选取的 input 元素

:checked

$(":checked")

所有被选中的 input 元素

参阅

教程:jQuery 元素选择器语法

选择器允许您对元素组或单个元素进行操作。

jQuery 选择器

在前面的章节中,我们展示了一些有关如何选取 HTML 元素的实例。

关键点是学习 jQuery 选择器是如何准确地选取您希望应用效果的元素。

jQuery 元素选择器和属性选择器允许您通过标签名、属性名或内容对 HTML 元素进行选择。

选择器允许您对 HTML 元素组或单个元素进行操作。

在 HTML DOM 术语中:

选择器允许您对 DOM 元素组或单个 DOM 节点进行操作。

jQuery 元素选择器

jQuery 使用 CSS 选择器来选取 HTML 元素。

$("p") 选取 <p> 元素。

$("p.intro") 选取所有 class="intro" 的 <p> 元素。

$("p#demo") 选取 id="demo" 的第一个 <p> 元素。

jQuery 属性选择器

jQuery 使用 XPath 表达式来选择带有给定属性的元素。

$("[href]") 选取所有带有 href 属性的元素。

$("[href='#']") 选取所有带有 href 值等于 "#" 的元素。

$("[href!='#']") 选取所有带有 href 值不等于 "#" 的元素。

$("[href$='.jpg']") 选取所有 href 值以 ".jpg" 结尾的元素。

jQuery CSS 选择器

jQuery CSS 选择器可用于改变 HTML 元素的 CSS 属性。

下面的例子把所有 元素的背景颜色更改为红色:

实例

$("p").css("background-color","red");

TIY

更多的实例

语法

描述

$(this)

当前 HTML 元素

$("p")

所有 <p> 元素

$("p.intro")

所有 class="intro" 的 <p> 元素

$(".intro")

所有 class="intro" 的元素

$("#intro")

id="intro" 的第一个元素

$("ul li:first")

每个 <ul> 的第一个 <li> 元素

$("[href$='.jpg']")

所有带有以 ".jpg" 结尾的 href 属性的属性

$("div#intro .head")

id="intro" 的 <div> 元素中的所有 class="head" 的元素

如需完整的参考手册,请访问我们的 jQuery 选择器参考手册

13.jQuery 参考手册 - 事件

Query 事件方法

事件方法会触发匹配元素的事件,或将函数绑定到所有匹配元素的某个事件。

触发实例:

$("button#demo").click()

上面的例子将触发 id="demo" 的 button 元素的 click 事件。

绑定实例:

$("button#demo").click(function(){$("img").hide()})

上面的例子会在点击 id="demo" 的按钮时隐藏所有图像。

方法

描述

ready()

文档就绪事件(当 HTML 文档就绪可用时)

blur()

触发、或将函数绑定到指定元素的 blur 事件

change()

触发、或将函数绑定到指定元素的 change 事件

click()

触发、或将函数绑定到指定元素的 click 事件

dblclick()

触发、或将函数绑定到指定元素的 double click 事件

error()

触发、或将函数绑定到指定元素的 error 事件

focus()

触发、或将函数绑定到指定元素的 focus 事件

keydown()

触发、或将函数绑定到指定元素的 key down 事件

keypress()

触发、或将函数绑定到指定元素的 key press 事件

keyup()

触发、或将函数绑定到指定元素的 key up 事件

load()

触发、或将函数绑定到指定元素的 load 事件

mousedown()

触发、或将函数绑定到指定元素的 mouse down 事件

mouseenter()

触发、或将函数绑定到指定元素的 mouse enter 事件

mouseleave()

触发、或将函数绑定到指定元素的 mouse leave 事件

mousemove()

触发、或将函数绑定到指定元素的 mouse move 事件

mouseout()

触发、或将函数绑定到指定元素的 mouse out 事件

mouseover()

触发、或将函数绑定到指定元素的 mouse over 事件

mouseup()

触发、或将函数绑定到指定元素的 mouse up 事件

resize()

触发、或将函数绑定到指定元素的 resize 事件

scroll()

触发、或将函数绑定到指定元素的 scroll 事件

select()

触发、或将函数绑定到指定元素的 select 事件

submit()

触发、或将函数绑定到指定元素的 submit 事件

unload()

触发、或将函数绑定到指定元素的 unload 事件

jQuery 事件处理方法

事件处理方法把事件处理器绑定至匹配元素。

方法

触发

$(selector).bind(event)

向匹配元素添加一个或更多事件处理器

$(selector).delegate(selector, event)

向匹配元素添加一个事件处理器,现在或将来

$(selector).die()

移除所有通过 live() 函数添加的事件处理器

$(selector).live(event)

向匹配元素添加一个事件处理器,现在或将来

$(selector).one(event)

向匹配元素添加一个事件处理器。该处理器只能触发一次。

$(selector).unbind(event)

从匹配元素移除一个被添加的事件处理器

$(selector).undelegate(event)

从匹配元素移除一个被添加的事件处理器,现在或将来

$(selector).trigger(event)

所有匹配元素的指定事件

$(selector).triggerHandler(event)

第一个被匹配元素的指定事件

参阅

教程:jQuery 元素选择器语法

14.jQuery 参考手册 - 效果

Query 效果函数

Hide / Show

描述

show()

显示被选的元素

hide()

隐藏被选的元素

toggle()

对被选元素进行隐藏和显示的切换

 

 

Slide

 

slideDown()

通过调整高度来滑动显示被选元素

slideUp()

通过调整高度来滑动隐藏被选元素

slideToggle()

对被选元素进行滑动隐藏和滑动显示的切换

 

 

Fade in / out

 

fadeIn()

淡入被选元素至完全不透明

fadeOut()

淡出被选元素至完全不透明

fadeTo()

把被选元素减弱至给定的不透明度

 

 

Animation

 

animate()

对被选元素应用自定义的动画

stop()

停止在被选元素上运行动画

 

 

Queue

 

clearQueue()

对被选元素移除所有排队的函数(仍未运行的)

delay()

对被选元素的所有排队函数(仍未运行)设置延迟

dequeue()

运行被选元素的下一个排队函数

queue()

显示被选元素的排队函数

参阅

教程:jQuery 元素选择器语法

15.jQuery 参考手册 - 文档操作

jQuery 文档操作方法

这些方法对于 XML 文档和 HTML 文档均是适用的,除了:html()

方法

描述

addClass()

向匹配的元素添加指定的类名。

after()

在匹配的元素之后插入内容。

append()

向匹配的元素内部追加内容。

appendTo()

向匹配的元素内部追加内容。

attr()

设置或返回匹配元素的属性和值。

before()

在每个匹配的元素之前插入内容。

clone()

创建匹配元素集合的副本。

detach()

从 DOM 中移除匹配元素集合。

empty()

删除匹配的元素集合中所有的子节点。

hasClass()

检查匹配的元素是否拥有指定的类。

html()

设置或返回匹配的元素集合中的 HTML 内容。

insertAfter()

把匹配的元素插入到另一个指定的元素集合的后面。

insertBefore()

把匹配的元素插入到另一个指定的元素集合的前面。

prepend()

向每个匹配的元素内部前置内容。

prependTo()

向每个匹配的元素内部前置内容。

remove()

移除所有匹配的元素。

removeAttr()

从所有匹配的元素中移除指定的属性。

removeClass()

从所有匹配的元素中删除全部或者指定的类。

replaceAll()

用匹配的元素替换所有匹配到的元素。

replaceWith()

用新内容替换匹配的元素。

text()

设置或返回匹配元素的内容。

toggleClass()

从匹配的元素中添加或删除一个类。

unwrap()

移除并替换指定元素的父元素。

val()

设置或返回匹配元素的值。

wrap()

把匹配的元素用指定的内容或元素包裹起来。

wrapAll()

把所有匹配的元素用指定的内容或元素包裹起来。

wrapinner()

将每一个匹配的元素的子内容用指定的内容或元素包裹起来。

参阅

教程:jQuery 元素选择器语法

16.jQuery 参考手册 - 属性操作

jQuery 属性操作方法

下面列出的这些方法获得或设置元素的 DOM 属性。

这些方法对于 XML 文档和 HTML 文档均是适用的,除了:html()

方法

描述

addClass()

向匹配的元素添加指定的类名。

attr()

设置或返回匹配元素的属性和值。

hasClass()

检查匹配的元素是否拥有指定的类。

html()

设置或返回匹配的元素集合中的 HTML 内容。

removeAttr()

从所有匹配的元素中移除指定的属性。

removeClass()

从所有匹配的元素中删除全部或者指定的类。

toggleClass()

从匹配的元素中添加或删除一个类。

val()

设置或返回匹配元素的值。

注释:jQuery 文档操作参考手册中也列出了以上方法。本参考页的作用是方便用户单独查阅有关属性操作方面的方法。

参阅

教程:jQuery 元素选择器语法

17.jQuery 参考手册 - CSS 操作

jQuery CSS 操作函数

下面列出的这些方法设置或返回元素的 CSS 相关属性。

CSS 属性

描述

css()

设置或返回匹配元素的样式属性。

height()

设置或返回匹配元素的高度。

offset()

返回第一个匹配元素相对于文档的位置。

offsetParent()

返回最近的定位祖先元素。

position()

返回第一个匹配元素相对于父元素的位置。

scrollTop()

设置或返回匹配元素相对滚动条顶部的偏移。

scrollLeft()

设置或返回匹配元素相对滚动条左侧的偏移。

width()

设置或返回匹配元素的宽度。

参阅

教程:jQuery 元素选择器语法

教程:CSS 教程

参考手册:CSS 参考手册

18.jQuery 参考手册 - Ajax

jQuery Ajax 操作函数

jQuery 库拥有完整的 Ajax 兼容套件。其中的函数和方法允许我们在不刷新浏览器的情况下从服务器加载数据。

函数

描述

jQuery.ajax()

执行异步 HTTP (Ajax) 请求。

.ajaxComplete()

当 Ajax 请求完成时注册要调用的处理程序。这是一个 Ajax 事件。

.ajaxError()

当 Ajax 请求完成且出现错误时注册要调用的处理程序。这是一个 Ajax 事件。

.ajaxSend()

在 Ajax 请求发送之前显示一条消息。

jQuery.ajaxSetup()

设置将来的 Ajax 请求的默认值。

.ajaxStart()

当首个 Ajax 请求完成开始时注册要调用的处理程序。这是一个 Ajax 事件。

.ajaxStop()

当所有 Ajax 请求完成时注册要调用的处理程序。这是一个 Ajax 事件。

.ajaxSuccess()

当 Ajax 请求成功完成时显示一条消息。

jQuery.get()

使用 HTTP GET 请求从服务器加载数据。

jQuery.getJSON()

使用 HTTP GET 请求从服务器加载 JSON 编码数据。

jQuery.getScript()

使用 HTTP GET 请求从服务器加载 JavaScript 文件,然后执行该文件。

.load()

从服务器加载数据,然后把返回到 HTML 放入匹配元素。

jQuery.param()

创建数组或对象的序列化表示,适合在 URL 查询字符串或 Ajax 请求中使用。

jQuery.post()

使用 HTTP POST 请求从服务器加载数据。

.serialize()

将表单内容序列化为字符串。

.serializeArray()

序列化表单元素,返回 JSON 数据结构数据。

参阅

教程:jQuery 元素选择器语法

教程:Ajax 教程

19.jQuery 参考手册 - 遍历

jQuery 遍历函数

jQuery 遍历函数包括了用于筛选、查找和串联元素的方法。

函数

描述

.add()

将元素添加到匹配元素的集合中。

.andSelf()

把堆栈中之前的元素集添加到当前集合中。

.children()

获得匹配元素集合中每个元素的所有子元素。

.closest()

从元素本身开始,逐级向上级元素匹配,并返回最先匹配的祖先元素。

.contents()

获得匹配元素集合中每个元素的子元素,包括文本和注释节点。

.each()

对 jQuery 对象进行迭代,为每个匹配元素执行函数。

.end()

结束当前链中最近的一次筛选操作,并将匹配元素集合返回到前一次的状态。

.eq()

将匹配元素集合缩减为位于指定索引的新元素。

.filter()

将匹配元素集合缩减为匹配选择器或匹配函数返回值的新元素。

.find()

获得当前匹配元素集合中每个元素的后代,由选择器进行筛选。

.first()

将匹配元素集合缩减为集合中的第一个元素。

.has()

将匹配元素集合缩减为包含特定元素的后代的集合。

.is()

根据选择器检查当前的匹配元素集合,如果存在至少一个匹配元素,则返回 true

.last()

将匹配元素集合缩减为集合中的最后一个元素。

.map()

把当前匹配集合中的每个元素传递给一个函数,产生包含返回值的新的 jQuery 对象。

.next()

获得匹配元素集合中每个元素紧邻的同辈元素。

.nextAll()

获得匹配元素集合中每个元素之后的所有同辈元素,由选择器进行筛选(可选)。

.nextUntil()

获得每个元素之后所有的同辈元素,直到遇到匹配选择器的元素为止。

.not()

从匹配元素集合中删除元素。

.offsetParent()

获得用于定位的第一个父元素。

.parent()

获得当前匹配元素集合中每个元素的父元素,由选择器筛选(可选)。

.parentsUntil()

获得当前匹配元素集合中每个元素的祖先元素,直到遇到匹配选择器的元素为止。

.prev()

获得匹配元素集合中每个元素紧邻的前一个同辈元素,由选择器筛选(可选)。

.prevAll()

获得匹配元素集合中每个元素之前的所有同辈元素,由选择器进行筛选(可选)。

.prevUntil()

获得每个元素之前所有的同辈元素,直到遇到匹配选择器的元素为止。

.siblings()

获得匹配元素集合中所有元素的同辈元素,由选择器筛选(可选)。

.slice()

将匹配元素集合缩减为指定范围的子集。

参阅

教程:jQuery 元素选择器语法

20.jQuery 参考手册 - 数据存储

jQuery 数据存储函数

这些方法允许我们将指定的 DOM 元素与任意数据相关联。

函数

描述

.data()

存储与匹配元素相关的任意数据。

jQuery.data()

存储与指定元素相关的任意数据。

.removeData()

移除之前存放的数据。

jQuery.removeData()

移除之前存放的数据。

参阅

参考手册:jQuery 队列控制

教程:jQuery 元素选择器语法

21.jQuery 参考手册 - 队列控制

jQuery 队列控制函数

函数

描述

.clearQueue()

从队列中删除所有未运行的项目。

.dequeue()

从队列最前端移除一个队列函数,并执行它。

jQuery.dequeue()

从队列最前端移除一个队列函数,并执行它。

.queue()

显示或操作匹配元素所执行函数的队列。

jQuery.queue()

显示或操作匹配元素所执行函数的队列。

参阅

教程:jQuery 元素选择器语法

22.jQuery 参考手册 - 核心

jQuery 核心函数

函数

描述

jQuery()

接受一个字符串,其中包含了用于匹配元素集合的 CSS 选择器。

jQuery.noConflict()

运行这个函数将变量 的控制权让渡给第一个实现它的那个库。

参阅

教程:jQuery 元素选择器语法

展开阅读全文

没有更多推荐了,返回首页