从零开始学习jQuery (二) 万能的选择器

本系列文章导航

从零开始学习jQuery (一) 开天辟地入门篇

从零开始学习jQuery (二) 万能的选择器

从零开始学习jQuery (三) 管理jQuery包装集

从零开始学习jQuery (四) 使用jQuery操作元素的属性与样式

从零开始学习jQuery (五) 事件与事件对象

从零开始学习jQuery (六) jQuery中的Ajax

从零开始学习jQuery (七) jQuery动画-让页面动起来!

从零开始学习jQuery (八) 插播:jQuery实施方案

从零开始学习jQuery (九) jQuery工具函数

从零开始学习jQuery (十) jQueryUI常用功能实战

从零开始学习jQuery (十一) 实战表单验证与自动完成提示插件


 

一.摘要

本章讲解jQuery最重要的选择器部分的知识. 有了jQuery的选择器我们几乎可以获取页面上任意的一个或一组对象, 可以明显减轻开发人员的工作量.

 

二.前言

编写任何javascript程序我们要首先获得对象, jQuery选择器能彻底改变我们平时获取对象的方式, 可以获取几乎任何语意的对象, 比如"拥有title属性并且值中包含test的<a>元素", 完成这些工作只需要编写一个jQuery选择器字符串. 学习jQuery选择器是学习jQuery最重要的一步.

 

三.Dom对象和jQuery包装集

无论是在写程序还是看API文档,  我们要时刻注意区分Dom对象和jQuery包装集.

1.Dom对象

在传统的javascript开发中,我们都是首先获取Dom对象,比如:

    var div = document.getElementById("testDiv");
    var divs = document.getElementsByTagName("div");


我们经常使用 document.getElementById 方法根据id获取单个Dom对象, 或者使用 document.getElementsByTagName 方法根据HTML标签名称获取Dom对象集合.

另外在事件函数中, 可以通过在方法函数中使用this引用事件触发对象(但是在多播事件函数中IE6存在问题), 或者使用event对象的target(FF)或srcElement(iIE6)获取到引发事件的Dom对象.

注意我们这里获取到的都是Dom对象, Dom对象也有不同的类型比如input, div, span等.  Dom对象只有有限的属性和方法:

image

 

2.jQuery包装集

jQuery包装集可以说是Dom对象的扩充.在jQuery的世界中将所有的对象, 无论是一个还是一组, 都封装成一个jQuery包装集,比如获取包含一个元素的jQuery包装集:

var jQueryObject = $("#testDiv");


jQuery包装集都是作为一个对象一起调用的. jQuery包装集拥有丰富的属性和方法, 这些都是jQuery特有的:

image


3.Dom对象与jQuery对象的转换

(1) Dom转jQuery包装集

如果要使用jQuery提供的函数,  就要首先构造jQuery包装集.  我们可以使用本文即将介绍的jQuery选择器直接构造jQuery包装集,比如:

$("#testDiv");

上面语句构造的包装集只含有一个id是testDiv的元素.


或者我们已经获取了一个Dom元素,比如:

var div = document.getElementById("testDiv");


上面的代码中div是一个Dom元素, 我们可以将Dom元素转换成jQuery包装集:

var domToJQueryObject = $(div);


小窍门:因为有了智能感知, 所以我们可以通过智能感知的方法列表来判断一个对象啊是Dom对象还是jQuery包装集.

(2) jQuery包装集转Dom对象

jQuery包装集是一个集合, 所以我们可以通过索引器访问其中的某一个元素:

var domObject = $("#testDiv")[0];


注意, 通过索引器返回的不再是jQuery包装集, 而是一个Dom对象!

jQuery包装集的某些遍历方法,比如each()中, 可以传递遍历函数, 在遍历函数中的this也是Dom元素,比如:

$("#testDiv").each(function() { alert(this) })


如果我们要使用jQuery的方法操作Dom对象,怎么办? 用上面介绍过的转换方法即可:

$("#testDiv").each(function() { $(this).html("修改内容") })


小结: 先让大家明确Dom对象和jQuery包装集的概念, 将极大的加快我们的学习速度. 我在学习jQuery的过程中就花了很长时间没有领悟到两者的具体差异, 因为书上并没有专门讲解两者的区别, 所以经常被"this指针为何不能调用jQuery方法"等问题迷惑.  直到某一天豁然开朗, 发现只要能够区分这两者, 就能够在写程序时变得清清楚楚.

 

四. 什么是jQuery选择器

在Dom编程中我们只能使用有限的函数根据id或者TagName获取Dom对象.

在jQuery中则完全不同,jQuery提供了异常强大的选择器用来帮助我们获取页面上的对象, 并且将对象以jQuery包装集的形式返回.

首先来看看什么是选择器:

    //根据ID获取jQuery包装集
    var jQueryObject = $("#testDiv");


上例中使用了ID选择器, 选取id为testDiv的Dom对象并将它放入jQuery包装集, 最后以jQuery包装集的形式返回.

"$"符号在jQuery中代表对jQuery对象的引用, "jQuery"是核心对象, 其中包含下列方法:

jQuery( expression, context )
Returns: jQuery

这个函数接收一个CSS选择器的字符串,然后用这个字符串去匹配一组元素。

This function accepts a string containing a CSS selector which is then used to match a set of elements.

jQuery( html, ownerDocument )
Returns: jQuery

根据HTML原始字符串动态创建Dom元素.

Create DOM elements on-the-fly from the provided String of raw HTML.

jQuery( elements )
Returns: jQuery

将一个或多个Dom对象封装jQuery函数功能(即封装为jQuery包装集)

Wrap jQuery functionality around a single or multiple DOM Element(s).

jQuery( callback )
Returns: jQuery

$(document).ready()的简写方式

A shorthand for $(document).ready().


上面摘选自jQuery官方手册.Returns的类型为jQuery即表示返回的是jQuery包装集.其中第一个方法有些问题, 官方接口写的是CSS选择器, 但是实际上这个方法不仅仅支持CSS选择器, 而是所有jQuery支持的选择器, 有些甚至是jQuery自定义的选择器(在CSS标准中不存在的选择器). 为了能让大家理解的更清楚,  我将方法修改如下:

jQuery( selector, context )
Returns: jQuery 包装集

根据选择器选取匹配的对象, 以jQuery包装集的形式返回. context可以是Dom对象集合或jQuery包装集, 传入则表示要从context中选择匹配的对象, 不传入则表示范围为文档对象(即页面全部对象).

上面这个方法就是我们选择器使用的核心方法.可以用"$"代替jQuery让语法更简介, 比如下面两句话的效果相同:

    //根据ID获取jQuery包装集
    var jQueryObject = $("#testDiv");

    //$是jQuery对象的引用:
    var jQueryObject = jQuery("#testDiv");


接下来让我们系统的学习jQuery选择器.

 

五.jQuery选择器全解


通俗的讲, Selector选择器就是"一个表示特殊语意的字符串". 只要把选择器字符串传入上面的方法中就能够选择不同的Dom对象并且以jQuery包装集的形式返回.

但是如何将jQuery选择器分类让我犯难. 因为书上的分类和jQuery官方的分类截然不同. 最后我决定以实用为主, 暂时不去了解CSS3选择器标准, 而按照jQuery官方的分类进行讲解.

jQuery的选择器支持CSS3选择器标准. 下面是W3C最新的CSS3选择器标准:

http://www.w3.org/TR/css3-selectors/

标准中的选择器都可以在jQuery中使用.

jQuery选择器按照功能主要分为"选择"和"过滤". 并且是配合使用的. 可以同时使用组合成一个选择器字符串. 主要的区别是"过滤"作用的选择器是指定条件从前面匹配的内容中筛选, "过滤"选择器也可以单独使用, 表示从全部"*"中筛选. 比如:

$(":[title]")

等同于:

$("*:[title]")

而"选择"功能的选择器则不会有默认的范围, 因为作用是"选择"而不是"过滤".

下面的选择器分类中,  带有"过滤器"的分类表示是"过滤"选择器,  否则就是"选择"功能的选择器.

jQuery选择器分为如下几类:

[说明]
1.点击"名称"会跳转到此方法的jQuery官方说明文档.
2.可以在下节中的jQuery选择器实验室测试各种选择器

1. 基础选择器 Basics

名称 说明 举例
#id 根据元素Id选择 $("divId") 选择ID为divId的元素
element 根据元素的名称选择, $("a") 选择所有<a>元素
.class 根据元素的css类选择 $(".bgRed") 选择所用CSS类为bgRed的元素
* 选择所有元素 $("*")选择页面所有元素
selector1,
selector2,
selectorN
可以将几个选择器用","分隔开然后再拼成一个选择器字符串.会同时选中这几个选择器匹配的内容. $("#divId, a, .bgRed")

 

[学习建议]: 大家暂时记住基础选择器即可, 可以直接跳到下一节"jQuery选择器实验室"进行动手练习, 以后再回来慢慢学习全部的选择器, 或者用到的时候再回来查询.

2.层次选择器 Hierarchy

名称 说明 举例
ancestor descendant 使用"form input"的形式选中form中的所有input元素.即ancestor(祖先)为from, descendant(子孙)为input. $(".bgRed div") 选择CSS类为bgRed的元素中的所有<div>元素.
parent > child 选择parent的直接子节点child.  child必须包含在parent中并且父类是parent元素. $(".myList>li") 选择CSS类为myList元素中的直接子节点<li>对象.
prev + next prev和next是两个同级别的元素. 选中在prev元素后面的next元素. $("#hibiscus+img")选在id为hibiscus元素后面的img对象.
prev ~ siblings  选择prev后面的根据siblings过滤的元素
注:siblings是过滤器
$("#someDiv~[title]")选择id为someDiv的对象后面所有带有title属性的元素

 

3.基本过滤器 Basic Filters

名称 说明 举例
:first 匹配找到的第一个元素 查找表格的第一行:$("tr:first")
:last 匹配找到的最后一个元素 查找表格的最后一行:$("tr:last")
:not(selector) 去除所有与给定选择器匹配的元素 查找所有未选中的 input 元素: $("input:not(:checked)")
:even 匹配所有索引值为偶数的元素,从 0 开始计数 查找表格的1、3、5...行:$("tr:even")
:odd 匹配所有索引值为奇数的元素,从 0 开始计数 查找表格的2、4、6行:$("tr:odd")
:eq(index) 匹配一个给定索引值的元素
注:index从 0 开始计数
查找第二行:$("tr:eq(1)")
:gt(index) 匹配所有大于给定索引值的元素
注:index从 0 开始计数
查找第二第三行,即索引值是1和2,也就是比0大:$("tr:gt(0)")
:lt(index) 选择结果集中索引小于 N 的 elements
注:index从 0 开始计数
查找第一第二行,即索引值是0和1,也就是比2小:$("tr:lt(2)")
:header 选择所有h1,h2,h3一类的header标签. 给页面内所有标题加上背景色: $(":header").css("background", "#EEE");
:animated 匹配所有正在执行动画效果的元素 只有对不在执行动画效果的元素执行一个动画特效:

$("#run").click(function(){
  $("div:not(:animated)").animate({ left: "+=20" }, 1000);
});

 

4. 内容过滤器 Content Filters

名称 说明 举例
:contains(text) 匹配包含给定文本的元素 查找所有包含 "John" 的 div 元素:$("div:contains('John')")
:empty 匹配所有不包含子元素或者文本的空元素 查找所有不包含子元素或者文本的空元素:$("td:empty")
:has(selector) 匹配含有选择器所匹配的元素的元素 给所有包含 p 元素的 div 元素添加一个 text 类: $("div:has(p)").addClass("test");
:parent 匹配含有子元素或者文本的元素 查找所有含有子元素或者文本的 td 元素:$("td:parent")

 

5.可见性过滤器  Visibility Filters

名称 说明 举例

:hidden

匹配所有的不可见元素

注:在1.3.2版本中, hidden匹配自身或者父类在文档中不占用空间的元素.如果使用CSS visibility属性让其不显示但是占位,则不输入hidden.

查找所有不可见的 tr 元素:$("tr:hidden")
:visible 匹配所有的可见元素 查找所有可见的 tr 元素:$("tr:visible")

6.属性过滤器 Attribute Filters

名称 说明 举例
[attribute] 匹配包含给定属性的元素 查找所有含有 id 属性的 div 元素:
$("div[id]")
[attribute=value] 匹配给定的属性是某个特定值的元素 查找所有 name 属性是 newsletter 的 input 元素:
$("input[name='newsletter']").attr("checked", true);
[attribute!=value] 匹配给定的属性是不包含某个特定值的元素 查找所有 name 属性不是 newsletter 的 input 元素:
$("input[name!='newsletter']").attr("checked", true);
[attribute^=value] 匹配给定的属性是以某些值开始的元素 $("input[name^='news']")
[attribute$=value] 匹配给定的属性是以某些值结尾的元素 查找所有 name 以 'letter' 结尾的 input 元素:
$("input[name$='letter']")
[attribute*=value]

匹配给定的属性是以包含某些值的元素

查找所有 name 包含 'man' 的 input 元素:
$("input[name*='man']")

[attributeFilter1][attributeFilter2][attributeFilterN] 复合属性选择器,需要同时满足多个条件时使用。 找到所有含有 id 属性,并且它的 name 属性是以 man 结尾的:
$("input[id][name$='man']")

7.子元素过滤器 Child Filters

名称 说明 举例
:nth-child(index/even/odd/equation)

匹配其父元素下的第N个子或奇偶元素

':eq(index)' 只匹配一个元素,而这个将为每一个父元素匹配子元素。:nth-child从1开始的,而:eq()是从0算起的!

可以使用:
nth-child(even)
:nth-child(odd)
:nth-child(3n)
:nth-child(2)
:nth-child(3n+1)
:nth-child(3n+2)

在每个 ul 查找第 2 个li:
$("ul li:nth-child(2)")
:first-child

匹配第一个子元素

':first' 只匹配一个元素,而此选择符将为每个父元素匹配一个子元素

在每个 ul 中查找第一个 li:
$("ul li:first-child")
:last-child

匹配最后一个子元素

':last'只匹配一个元素,而此选择符将为每个父元素匹配一个子元素

在每个 ul 中查找最后一个 li:
$("ul li:last-child")
:only-child

如果某个元素是父元素中唯一的子元素,那将会被匹配

如果父元素中含有其他元素,那将不会被匹配。

在 ul 中查找是唯一子元素的 li:
$("ul li:only-child")

8.表单选择器 Forms

名称 说明 解释
:input 匹配所有 input, textarea, select 和 button 元素 查找所有的input元素:
$(":input")
:text 匹配所有的文本框 查找所有文本框:
$(":text")
:password 匹配所有密码框 查找所有密码框:
$(":password")
:radio 匹配所有单选按钮 查找所有单选按钮
:checkbox 匹配所有复选框 查找所有复选框:
$(":checkbox")
:submit 匹配所有提交按钮 查找所有提交按钮:
$(":submit")
:image

匹配所有图像域

匹配所有图像域:
$(":image")
:reset 匹配所有重置按钮 查找所有重置按钮:
$(":reset")
:button 匹配所有按钮 查找所有按钮:
$(":button")
:file 匹配所有文件域 查找所有文件域:
$(":file")

9.表单过滤器 Form Filters

名称 说明 解释
:enabled

匹配所有可用元素

查找所有可用的input元素:
$("input:enabled")
:disabled 匹配所有不可用元素 查找所有不可用的input元素:
$("input:disabled")
:checked 匹配所有选中的被选中元素(复选框、单选框等,不包括select中的option) 查找所有选中的复选框元素:
$("input:checked")
:selected 匹配所有选中的option元素 查找所有选中的选项元素:
$("select option:selected")

 

六 jQuery选择器实验室

jQuery选择器实验室使用的是"jQuery实战"一书中的代码, 感觉对于学习选择器很有帮助.

我们的实验对象是一个拥有很多元素的页面:

image

在实验室页面的"Selector"输入框中输入jQuery选择器表达式,  所有匹配表达式的元素会显示红框:

image

如上图所示,  在输入".myList"后点击"Apply", 下面的输出框会显示运行结果, 右侧会将选中的元素用红框显示.

代码在本章最后可以下载.

 

七.API文档

jQuery官方API: http://docs.jquery.com/

中文在线API: http://jquery.org.cn/visual/cn/index.xml

中文jQuery手册下载: http://files.cnblogs.com/zhangziqiu/jquery_api.rar

 

八.总结

本章节讲解的jQuery依然属于基础支持, 所以没有太多的应用实例.  虽然基础但是很难一次全部记住, jQuery选择器可以说是最考验一个人jQuery功力的地方. 下一章我们讲解如何操作jQuery包装集以及动态创建新元素.

本章代码下载:

http://files.cnblogs.com/zhangziqiu/Code-jQueryStudy-2.rar

作者:张子秋
出处:http://www.cnblogs.com/zhangziqiu/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
posted @ 2009-05-03 00:36 ziqiu.zhang 阅读(64014) 评论(75) 编辑 收藏

 回复 引用 查看   
#1楼 2009-05-03 01:08 GWPBrian      
哈哈,抢个沙发!
 回复 引用 查看   
#2楼 2009-05-03 02:14 Jason.Wei      
沙发没抢着,
哭...

 回复 引用 查看   
#3楼 2009-05-03 09:34 侯垒      
抢个地板。
 回复 引用 查看   
#4楼 2009-05-03 09:57 frog      
期待下集精彩
 回复 引用 查看   
#5楼 2009-05-03 10:47 ilovedotnet      
楼主的排版很不错啊!
 回复 引用 查看   
#6楼 2009-05-03 17:36 Q.Lee.lulu      
“jQuery包装集”是否考虑改成“jQuery对象”?
 回复 引用 查看   
#7楼[楼主] 2009-05-03 18:54 ziqiu.zhang      
@Q.Lee.lulu
--引用--------------------------------------------------
Q.Lee.lulu: “jQuery包装集”是否考虑改成“jQuery对象”?
--------------------------------------------------------
我是使用的"jQuery实战"一书中的名称. 包装集能够比较好的说明是一个集合,而对象常指单个实例. 马上发表文章讲解如何操作包装集, 比如添加一个元素, 删除一个元素等.操作的都是集合. 感觉"包装集"这个名称好理解一点.

 回复 引用 查看   
#8楼 2009-05-03 20:29 文明的天空      
为楼主的努力鼓掌,道一声“楼主五一心苦”。
 回复 引用 查看   
#9楼 2009-05-03 22:09 Q.Lee.lulu      
@ziqiu.zhang
:) 没看过jQuery的书呢,呵呵。。。

 回复 引用 查看   
#10楼 2009-05-03 23:26 沉默杨仔      
写得非常好.你的文章让我开始正式学习 jquery,表格已打印.呵呵
有两点疑问:
一.$是jquery对象的引象.
我可以这样写:jQuery("#testDiv").,也可以这样写:$("#testDiv").,是否可以创建新的jQuery引用?如~("#testDiv")..
二.
@Q.Lee.lulu
--引用--------------------------------------------------
Q.Lee.lulu: “jQuery包装集”是否考虑改成“jQuery对象”?
--------------------------------------------------------
我是使用的"jQuery实战"一书中的名称. 包装集能够比较好的说明是一个集合,而对象常指单个实例. 马上发表文章讲解如何操作包装集, 比如添加一个元素, 删除一个元素等.操作的都是集合. 感觉"包装集"这个名称好理解一点.

这段话让我有些糊涂.到底Returns: jQuery是指对象还是集合?楼主的回复是否指$()可能返回多个对象?不然不能说明是集合(一个新名词让我有点犯晕了.呵呵).

 回复 引用 查看   
#11楼[楼主] 2009-05-04 09:29 ziqiu.zhang      
@沉默杨仔
一. 理论上可以使用别的符号替代$, 但是需要自己扩展jQuery, 在jQuery的js文件后添加如下代码:
windows.~ = window.jQuery
但是上面的代码不能用因为"~"符号无能使用,我试了试好像只有"$"符号可以当作变量使用.你可以自己再试试.

二. Returns: jQuery 是指文中的jQuery包装集, 我理解在jQuery的世界里jQuery对象就是jQuery包装集, jQuery这个类型永远是以集合的形式出现. 所以我没有翻译成jQuery对象. "包装集"其实就是集合, 原书如此翻译是因为jQuery中有"包装"相关的函数, wrapper翻译过来也是包装集的意思.

 回复 引用 查看   
#12楼 2009-05-04 22:50 sig556      
学习。。。
 回复 引用 查看   
#13楼 2009-05-05 11:15 yay      
学习,子秋很强大
 回复 引用 查看   
#14楼 2009-05-05 11:17 yay      
右边一些文字不能显示,不知是不是我的浏览器问题
 回复 引用   
#15楼 2009-05-05 13:29 vf[未注册用户]
好东西,谢谢楼主
 回复 引用   
#16楼 2009-05-06 11:51 黑泡泡[未注册用户]
我在安装VS90SP1-KB958502-x86.exe时提示:“此计算机上没有安装本软件更新支持的产品。单击“取消”退出安装程序。”
这是为什么??我已经安装了vs2008了呀?!

 回复 引用   
#17楼 2009-05-06 13:13 hikari
问个简单的问题:

title属性为“myTitle1”的DIV 怎么写选择器才对?

 回复 引用 查看   
#18楼 2009-05-08 15:04 阿滨       
$("div [title=myTitle1]")
 回复 引用 查看   
#19楼[楼主] 2009-05-14 13:47 ziqiu.zhang      
@阿滨
good!给你100分:)

 回复 引用 查看   
#20楼 2009-05-24 23:40 ::似水无痕::      
@黑泡泡
你打了SP1补丁了没有?估计没有

 回复 引用 查看   
#21楼 2009-05-30 14:48 Ss_Andy      
如果是<div id="msg" title="myTitle1">中文</div>
$("div [title=myTitle1]")
这样是可以的,如果我是按钮呢
<input id="btnShow" type="button" title="abc" value="显示" />
$("button [title=abc]")

就不行了??

 回复 引用 查看   
#22楼 2009-06-02 16:08 yyfrankyy      
@Ss_Andy
应该这样写:
$(":button[title='abc']")

 回复 引用 查看   
#23楼 2009-06-05 09:26 Ss_Andy      
--引用--------------------------------------------------
yyfrankyy: @Ss_Andy
应该这样写:
$(&quot;:button[title='abc']&quot;)
--------------------------------------------------------


非常感谢!

 回复 引用   
#24楼 2009-07-03 14:23 hechaner
博主,有个问题想请教一下

我有一个点击刷新验证码的按钮
方法我是这么写的
//更换验证码
function changeCheckCode()
{
$("#CodeImg").src="CheckCode.aspx?tmp="+Math.random();
}

不能实现更换验证码图片(验证码图片是CheckCode.aspx后台代码生成的)
如果改成
document.getElementById("CodeImg").src="CheckCode.aspx?tmp="+Math.random();

是可以的 后来我又按照您这篇文章 把jQuery包装集转成DOM对象
($("#CodeImg")[0]).src="CheckCode.aspx?tmp="+Math.random();
这样也是可行的
请问这是问什么呢?jQuery包装集和DOM对象的本质区别是什么呢?

 回复 引用   
#25楼 2009-07-31 13:48 Joinzheng[未注册用户]
好东西!期待有更好的说明!!
 回复 引用 查看   
#26楼 2009-08-03 10:52 yy2056      
引用hechaner:博主,有个问题想请教一下
<br/>
<br/>我有一个点击刷新验证码的按钮
<br/>方法我是这么写的
<br/>//更换验证码
<br/>function changeCheckCode()
<br/>{
<br/> $("#CodeImg").src="CheckCode.aspx?tmp="+Math.random();
<br/>}
<br/>
<br/>不能实现更换验证码图片(验证码图片是CheckCode.aspx后台代码生成的)
<br/>如果改成
<br/>document.getElementById("CodeImg").src="CheckCode.aspx?tmp="+Math.random();
<br/>
<br/>是可以的 后来我又按照您这篇文章 把jQuery包装集转成DOM对象
<br/>($("#CodeImg")[0]).src="CheckCode.aspx?tmp="+Math.random();
<br/>这样也是可行的
<br/>请问这是问什么呢?jQuery包装集和DOM对象的本质区别是什么呢?


同样期待回答

 回复 引用 查看   
#27楼 2009-08-03 11:25 这世界真惨      
@hechaner
其实两者没有大的区别,关键是他们的方法不一样,打个比方,同样是IE内核,如果你用遨游,你就得参照遨游设置,你不能用IE来设置遨游了,所以要使用JQUERY方法的时候必须是JQUERY包装集,而使用JAVASCRIPT方法的时候必须是JAVASCRIPT对象,只要注意这点,就不用管太多了~~~最大的难度其实在于区分是JQUERY包装集还是JAVASCRIPT对象,这是我的一点浅见,见笑了

 回复 引用 查看   
#28楼 2009-08-03 12:38 这世界真惨      
@hechaner
从有个角度理解也许更容易点吧,虽然不一定正确,我们可以把JQUERY包装集理解成是由JAVASCRIPT对象组成的数组,这样两个构成不同了,方法也就不通用了

 回复 引用   
#29楼 2009-08-26 11:12 smk[未注册用户]
虽然我已经比较熟练jQuery了,但还是支持楼主。毕竟是用心在做嘛。支持加油comeon。
 回复 引用   
#30楼 2009-08-28 14:21 turner[未注册用户]
引用这世界真惨:
@hechaner
其实两者没有大的区别,关键是他们的方法不一样,打个比方,同样是IE内核,如果你用遨游,你就得参照遨游设置,你不能用IE来设置遨游了,所以要使用JQUERY方法的时候必须是JQUERY包装集,而使用JAVASCRIPT方法的时候必须是JAVASCRIPT对象,只要注意这点,就不用管太多了~~~最大的难度其实在于区分是JQUERY包装集还是JAVASCRIPT对象,这是我的一点浅见,见笑了


看看jquery的源代码,就知道了

 回复 引用 查看   
#31楼 2009-09-03 10:34 xiao丫丫      
支持下,真不错
 回复 引用 查看   
#32楼 2009-09-08 15:54 寻自己      
支持楼主,好文章
 回复 引用 查看   
#33楼 2009-09-08 17:29 Ryan Boo      
这个地方写错了。
3.基本过滤器 Basic Filters
:odd :even 这两个的解释写反了。

 回复 引用   
#34楼 2009-09-16 15:21 dawnco[未注册用户]
您写的太好了! 非常感谢
 回复 引用 查看   
#35楼 2009-09-16 17:43 王金平      
基础选择器 Basics 中 $("divId") 选择ID为divId的元素是不是写错了 应该是 $("#divId")吧
 回复 引用 查看   
#36楼 2009-09-16 17:45 王金平      
jQuery选择器实验室 在哪可以看到
 回复 引用 查看   
#37楼 2009-09-21 16:59 Mr雨      
写的很好,很容易理解~~

有个疑问:微软主推这个吗?现在用Jquery 多么~~

 回复 引用   
#38楼 2009-09-22 22:43 niu90[未注册用户]
@Ryan Boo
没有错哦,楼主说的索引哦

 回复 引用 查看   
#39楼 2009-09-23 08:20 Ryan Boo      
@niu90
哦,是举例挫了。

 回复 引用   
#40楼 2009-09-23 14:55 niu90[未注册用户]
@Ryan Boo
举例也没错哦,您可以试试
<table>
<tr><td>aa</td></tr>
<tr><td>bb</td></tr>
<tr><td>cc</td></tr>
</table>

$("tr:even").each(function(index){alert($(this).text())});
结果:
aa cc

 回复 引用 查看   
#41楼 2009-10-05 20:16 小赵。      
@hechaner
使用选择器获取到的对象都为JQuery包装集,你的地一段代码是直接调用获取到的包装集的src属性,那样是肯定获取不到的,你需要写成$("#CodeImg")[0].src
ziqiu.Zhang已经详细的说明了..

 回复 引用 查看   
#42楼 2009-10-05 20:19 小赵。      
@hechaner
个人认为包装集只是封装了一系列的DOM操作方法,比如说addClass,removeClass,他的底层应该还是对通过选择器获取到的DOM对象进行了处理

 回复 引用 查看   
#43楼 2009-10-14 22:18 kaixin001      
引用Ss_Andy:如果是<div id="msg" title="myTitle1">中文</div>
<br/>$("div [title=myTitle1]")
<br/>这样是可以的,如果我是按钮呢
<br/> <input id="btnShow" type="button" title="abc" value="显示" />
<br/>$("button [title=abc]")
<br/>
<br/>就不行了??
<br/>


这样子
$("button [@title=abc]")

这样返回一个jquery集合,不仅仅是唯一一个。tilte值可以重复相同的

 回复 引用 查看   
#44楼 2009-11-09 13:40 YeanJay      
$("div:contains('John')")
改成$("div:contains("John")")

比如:Lab实验室中div :contains(’Hello‘)是不行的
div :contains("Hello")是可以的。
麻烦楼主那个表格里改一下

 回复 引用 查看   
#45楼 2009-12-07 15:48 马娟      
vs 中的函数的提示 有中文的吗
 回复 引用 查看   
#46楼 2009-12-10 15:27 WangKai      
请问一下,jQuery包装集和DOM对象的本质区别是什么呢
 回复 引用 查看   
#47楼 2009-12-15 15:32 混世者      
这个选择器的实验网页非常好,谢谢
 回复 引用 查看   
#48楼 2010-01-14 10:59 诡计的不老歌      
$("divId") 选择ID为divId的元素

是不是应该是

$("#divId") 选择ID为divId的元素

 回复 引用 查看   
#49楼 2010-03-16 11:46 SilverNet      
谢谢楼主分享这么好用而全的东西
 回复 引用 查看   
#50楼 2010-03-29 20:52 T-Shine      
的确是好多好多内容!慢慢消化!
 回复 引用 查看   
#51楼 2010-04-11 15:16 cj21828      
好文章,继续学习,继续顶,
 回复 引用 查看   
#52楼 2010-07-29 10:01 天地不仁      
感谢楼主。。。
 回复 引用 查看   
#53楼 2010-08-10 10:39 cnyao      
"1. 基础选择器 Basics"中"#id"的"举例"似乎少了一个#号
例子很好

 回复 引用 查看   
#54楼 2010-08-10 14:31 Jack Fan      
支持楼主!
 回复 引用 查看   
#55楼 2010-10-12 17:21 sungcong      
学习
 回复 引用 查看   
#56楼 2011-01-16 19:06 coconut12      
楼主写得真好·
 回复 引用 查看   
#57楼 2011-02-18 10:49 破小孩程序员      
太感动咧 眼泪piapia滴
 回复 引用 查看   
#58楼 2011-03-25 11:14 小涡      
引用1. 基础选择器 Basics
名称 说明 举例
#id 根据元素Id选择 $("divId") 选择ID为divId的元素

$("divId") 应该这样写吧 $("#divId") ?

 回复 引用 查看   
#59楼 2011-03-31 17:56 bin_bin      
引用我靠,我太佩服你了,太牛了。  
 回复 引用 查看   
#60楼 2011-04-01 14:48 web初探者      
通过这个篇教程,启发我找到了一个可以在DW里面也有类似VS那样的只能提示啦 地址在。。http://www.blogjava.net/ywj-316/archive/2010/01/20/310215.html
有需要的童鞋可以去下一个

 回复 引用 查看   
#61楼 2011-04-01 15:17 JkD      
感谢LZ分享。
 回复 引用 查看   
#62楼 2011-04-12 14:55 nibamm      
我正在学习,拜膜贴主,写得很有条理,我之前对jQuery一窍不通,看了你的文章,感觉自己正在慢慢的深入。。。
辛苦了!

 回复 引用   
#63楼 2011-04-22 20:32 老怪物[未注册用户]
文章写的好啊,总结理解后的真知灼见。是我见过最好的jquery学习文章。
 回复 引用 查看   
#64楼 2011-05-16 14:47 Code0Chen      
在使劲学
 回复 引用 查看   
#65楼 2011-06-10 09:10 -可乐      
写的太好了,不得不顶
 回复 引用 查看   
#66楼 2011-07-01 14:43 目标RE      
好文要顶,学到了如何分辨DOM对象和jQuery对象.
 回复 引用   
#67楼 2011-07-12 16:20 而[未注册用户]
测试了下,tr:first怎么不显示呢?
 回复 引用 查看   
#68楼 2011-07-28 10:47 可乐果      
我是初学者,感觉这样很有效,谢谢楼主喽!
 回复 引用 查看   
#69楼 2011-08-01 17:44 minrui_fei      
哈哈,正是我想看的,楼主辛苦了
 回复 引用 查看   
#70楼 2011-09-01 17:26 耐得住寂寞      
无条件顶
 回复 引用 查看   
#71楼 2011-09-19 16:30 s0705130      
楼主啊,我如果早四个月看到你的这些文章,何至于此啊!恨晚
 回复 引用 查看   
#72楼 2011-11-01 16:51 紫色路人      
@诡计的不老歌
我也觉得,呵呵

 回复 引用 查看   
#73楼 2011-11-05 22:21 chenchun      
不错,学习了
 回复 引用 查看   
#74楼 2012-01-09 15:08 静子      
初学者,感谢楼主,思路很清晰啊,从0开始学习~
 回复 引用 查看   
#75楼 2012-01-20 17:43 nd      
本人初学者 , 犯错:下面这个语句要注意了
$("select").change(function () {
var str = "";
$("select option:selected").each(function () {
str += $(this).text() + " ";
});
$("div").text(str);
})//这里不能加分号结束,因为这句还没有结束
.trigger('change');
其实这个语句应该写成这样:
$("select").change(function () {
var str = "";
$("select option:selected").each(function () {
str += $(this).text() + " ";
});
$("div").text(str);
}).trigger('change');

发表评论

昵称: [登录] [注册]

主页:

邮箱:(仅博主可见)

评论内容:

  登录  注册

[使用Ctrl+Enter键快速提交评论]

0 1447992 tY2ATajCGKk=