`

jquery选择器

阅读更多

 

$ 的选择器部分 :
凡是运用 $, 其返回值是一个 object
$
选择器主要用于选择标签 . 基本用法是同 css 的选择器 . 但是 , 很让人兴奋的是 , 他支持常见的浏览器 , css 中很多选择器是 IE6 所不支持的 .
1.
基本选择器 (3 ):
$("
标签名 "), $("p") 是选取了所有的 p 标签节点
$("#id
"), $("#test") 是选取了 id test 的标签节点
$(".class
"), $(".test") 是选取了所有 class test 的标签节点
上面的 $(" 标签名 ") $(".class ") 返回的都是所有满足的节点 , 至于进一步筛选可以添加一些函数 , eq,gt,lt 等等 .
2.
组选择器 :
下面还是现做一个约定 : " 标签名或 #id 名或 .class " 记作 mix, mix 表示一个标签名 , 或一个 #id 或一个 .class.
$("mix,mix,mix,..."),
:$("div,#test1,p,.test2,#test3")  


3.
后代选择器 :
$("mix mix"),
当然可以是多个嵌套 , 但后代选择器可以是深层子代 , 所以 $("mix mix mix ...") 这种写法作用不大 . 例子 :$("div .test"): div 标签内的所有具有 test class 的后代元素 ( 就是被 div 嵌套的 class 属性为 test 的标签 )
可以见 DEMO


4.
子选择器 :
$("mix>mix"),
这个放在后代选择器后面是为了和它做对比 . 子选择器只能选择第一代子代 . 不处理深层嵌套 . 例子 :
$("div>.test")
<div><p class="test"></p></div>
对这里的 p 段落标签有效 . 但对
<div><p><p class="test"></p></p></div>
对这里的 p 段落标签无效 , 这里要用
$("div .test)

5.
临近选择器 :
$("mix+mix"),
选取下一个兄弟节点 . :$("div +#test"),id test 的的节点必须是 div 的下一个兄弟节点 .
<div></div><p id="test"></p>
$("div + #test") 中能取到 p 段落节点
<div></div><p></p><p id="test"></p>
则不能取到

6.
属性选择器 :
把属性选择器不放在 css 选择器里面是因为 jQuery 中写法是不一样的 . 至于 css 中写法可以参考我之前写的一篇 css 的选择器一文 .jQuery 中是和 xPath 类似的写法 :
$("mix[@attr]"):
选取所有该 mix 且具有 attr 属性的节点
$("mix[@attr=a_value"]):
选取所有该 mix 且具有 attr 属性并满足属性值为 a_value 的节点
$("mix[@attr^=a_value_head"]):attr
属性的属性值是以 a_value_head 开头的
$("mix[@attr$=a_value_end"]):attr
属性的属性值是以 a_value_end 结尾的
$("mix[@attr*=a_value"]):attr
属性的属性值中包含 a_value

7.
进一步选择器 :
这个名称是我自己起的 , 其实选择器组合都有进一步的意思 , 你明白后面所介绍的知识即可 .
具有限定子节点选择器 :$("mix1[mix2]"): 返回包含 mix2 mix1 节点 . :$("div[a]"): 包含 a 标签的 div.
这个和 $("div a") 不相同 . 后者表示 div 中的 a 标签 , 返回的是 a 标签对象 , 前者返回的是 div 标签对象
冒号限定结点选择器 :$("mix:condition"):mix 标签 , 并且满足限定条件 .
E:root:
类型为 E, 并且是文档的根元素
E:nth-child(n):
是其父元素的第 n 个类型为 E 的子元素 , 基数从 1 开始
E:first-child:
是其父元素的第 1 个类型为 E 的子元素
E:last-child:
是其父元素的最后一个类型为 E 的子元素
E:only-child:
且是其父元素的唯一一个类型为 E 的子元素
E:empty:
没有子元素(包括 text 节点)的类型为 E 的元素
E:enabled
E:disabled:
类型为 E, 允许或被禁止的用户界面元素
E:checked:
类型为 E, 处于选中状态的用户界面元素(例如单选按钮或复选框)
E:visible:
选择所有可见元素 (display 值为 block visible,visibility 值为 visible 元素 , 不包括 hide )
E:hidden:
选择所有隐藏元素 ( Hide , display 值为 block visible,visibility 值为 visible 的元素 )
E:not(s):
类型为 E, 不匹配选择器 s
E:eq(n),E:gt(n),E:lt(n):
元素限定
E:first:
相当于 E:eq(0)
E:last:
最后一个匹配的元素
E:even:
从匹配的元素集中取序数为偶数的元素
E:odd:
从匹配的元素集中取序数为奇数的元素
E:parent:
选择包含子元素(包含 text 节点)的所有元素
E:contains('test'):
选择所有含有指定文本的元素
表单选择器 :
E:input:
选择表单元素 (input,select,textarea,button)
E:text:
选择所有文本域 (type="text")
E:password:
选择所有密码域 (type="password")
E:radio:
选择所有单选按钮 (type="radio")
E:checkbox:
选择所有复选框 (type="checkbox")
E:submit:
选择所有提交按钮 (type="submit")
E:image:
选择所有图像域 (type="image")
E:reset:
选择所有清除域 (type="reset")
E:button:
选择所有按钮 (type="button")
当然包括 E:hidden

8.xPath
路径查询 :

先介绍下 xPath 的语法 :
/:
选取根节点
//:
选取文档中所有符合条件的节点 , 不管该节点位于何处
.:
选取当前节点
..:
选取单前节点的父节点
@:
选取属性 , 这个在之前说过了 ( 属性选择器 )
nodename:
选取节点下的所有节点
jQuery
中的应用 :
根节点是很少用到的 , 常用的如下面的例子 :
$("div/p")
相当于 $("div>p")
$("div//p")
相当于 $("div p")
$("//div/../p"):
所有 div 节点的父节点下的 p 标签
还有相对路径的写法以及支持的 Axis 选择器 , 还不是会应用 , 不介绍了 ... 已经一大堆了

$
的其他用法 :

$(html
节点 ): 根据提供的原始 HTML 标记字符串 , 动态创建由 jQuery 对象包装的 DOM 元素 . :
$("<div><p>Hello</p></div>").appendTo("#body");//
<div><p>Hello</p></div> 添加到 body 元素中
$(document):
网页文档对象
$(document.body):
网页 body 对象 , $("body") 是一样的
$(
函数 ):DOM 载入后就执行该函数 . 所以 $(document).ready() 可以写做 $()
$(
选择器部分 , 选择器来源 ): 这个举例说明
$("input:radio",document.forms[0]):
在文档的第一个表单中 , 搜索所有单选按钮
$("div",xml.responseXML):
查询指定 XML 文档中的所有 div 元素
选择器来源可以是 : 作为上下文的 DOM 元素 , 文档或 jQuery 对象
还有两个 :$.extend(prop) $.noConflict() 是和插件以及和其他库兼容的使用 , 以后再写

jQuery
core 部分还有 :

eq(
数字 ): 将匹配的元素集合缩减为一个元素。这个元素在匹配元素集合中的位置变为 0, 而集合长度变成 1
gt(
数字 ): 将匹配的元素集合缩减为给定位置之后的所有元素
lt(
数字 ): 将匹配的元素集合缩减为给定位置之前的所有元素
上面三个的例子 :
$("div:eq(1)")//
2 div
$("div:gt(2)")//
3 div 以及之后的 div
$("div:lt(2)")//
2 div 以及之前的 div, 即第 1 div 和第 2 div

length
size(): 当前匹配的元素数量

each():
以每一个匹配的元素作为上下文来执行一个函数。这意味着 , 每次执行传递进来的函数时 , 函数中的 this 关键字都指向一个不同的元素 ( 每次都是一个不同的匹配元素 ). 而且 , 在每次执行函数时 , 都会给函数传递一个表示作为执行环境的元素在匹配的元素集合中所处位置的数字值作为参数 .
$("img").each(function(i){ this.src = "test" + i + ".jpg"; });//
迭代图像 , 并设置它们的 src 属性

get():
如果没有参数 , 返回所有 , 是一个对象数组 ; 如果带参数 , 必须是数字 , 基数从 0 开始 . 例子 :
$("div").get():
返回一个 div 对象数组
$("div").get(1):
返回第二个 div 对象
index(
需求的元素节点对象 ): 返回数字 . 用个例子说明 :
$("div").index($(".test"))[1] //
表示从所有 div 节点中查找 class 属性为 test 的节点 . 并且找的是第二个节点 ( 基数从 0 开始 ). 返回值是该节点在 div 节点中的位置 ( 基数也是从 0 开始 ).

分享到:
评论

相关推荐

    jQuery选择器全解.

    ### jQuery选择器全解 #### 一、引言 jQuery是一种快速、简洁的JavaScript库,其核心特性之一便是强大的选择器引擎。通过jQuery选择器,开发者能够轻松地定位和操作DOM(Document Object Model)元素,极大地提高...

    JQuery选择器测试 离线版

    这个“JQuery选择器测试 离线版”是一个专门用于检验和学习jQuery选择器功能的应用,由一位国外专家创建,并进行了轻微的修改。** 在jQuery中,选择器分为多种类型,包括基础选择器、类别选择器、ID选择器、属性...

    jquery选择器入门详解小案例

    本篇文章将深入探讨jQuery选择器的入门知识,并通过实际的小案例帮助你理解和应用这些选择器。 jQuery选择器是jQuery库的核心部分,它们是用于在HTML文档中查找元素的工具。jQuery支持多种CSS选择器,包括基本选择...

    jQuery选择器的一个Bug

    然而,即便如此成熟的库,也难免存在一些已知的问题和限制,其中之一就是我们今天要探讨的"jQuery选择器的一个Bug"。 首先,我们要理解jQuery选择器的基本原理。jQuery基于CSS选择器,它允许开发者通过类似CSS的...

    jquery选择器速查表

    jquery选择器功能无比强大,用好了可以起到事半功倍的效果,这个资源把选择器单独列出来,便于方便查找

    jQuery选择器.rar

    这个名为"jQuery选择器.rar"的压缩包文件显然包含了关于jQuery选择器的相关学习资源,可能包括示例代码、教程文档等。这些内容可能与《锋利的jQuery第二版》这本书中的章节相匹配,该书是jQuery学习的经典参考资料之...

    jQuery基础选择器练习题

    在JavaScript的世界里,jQuery是一个非常流行和...记住,熟练掌握jQuery选择器将极大地提升你的前端开发效率,让你编写出更加简洁高效的代码。在学习过程中,不断实践和应用这些知识点,你将会成为一个jQuery的大师。

    PPT和案例\jQuery选择器

    jQuery选择器是jQuery库的核心特性之一,它极大地简化了JavaScript中的DOM元素选择和操作。jQuery完全继承了CSS的风格,并在此基础上提供了更强大和灵活的选择方式。以下是对jQuery选择器的详细说明: **1. 基本...

    基于jQuery选择器的整理集合

    jQuery选择器是jQuery库的核心部分,它提供了一种高效的方式来选取和操作DOM元素。这篇文章将对jQuery选择器进行深入的整理和介绍。 首先,jQuery选择器可以分为基本选择器、层级选择器、属性选择器、内容选择器...

    jQuery选择器全面总结

    这篇文章将对jQuery选择器进行全面总结,帮助开发者更好地理解和运用这些工具。 首先,我们要了解基本选择器,这是jQuery选择器的基础。包括: 1. **ID选择器**: 使用`#`符号后跟元素的ID,如`jQuery("#ID")`,它...

    jquery选择器应用实例

    在本实例中,我们将探讨如何利用jQuery选择器在Visual Studio 2010环境下进行高效而精确的网页元素选取。jQuery的选择器是其强大功能的核心,它们基于CSS选择器,但提供了更丰富的功能。 首先,让我们了解jQuery的...

    jQuery选择器总结

    jQuery选择器总结,网上下载的,非原创的,仅供参考,学习学习。

    jQuery选择器思维导图

    通过思维导图对知识进行梳理,以便记忆

    RIA应用开发:2-jquery选择器.ppt

    RIA 应用开发之 jQuery 选择器 jQuery 选择器是 RIA 应用开发中一个非常重要的概念, jQuery 选择器是 jQuery 库中的一部分,主要用来选择和操作 HTML 文档中的元素。下面是 jQuery 选择器的详细知识点: 1. ...

    jQuery选择器

    **jQuery选择器详解** jQuery库以其简洁易用的API闻名,其中最重要的部分之一就是选择器。选择器在jQuery中扮演着查找HTML元素的关键角色,使得开发者可以轻松地选取DOM中的特定元素进行操作。本文将深入探讨jQuery...

    jQuery选择器上机练习题及答案.rar

    (24)选择表格中第3行,标题行不算(要求用nth-child()过滤器) 上机任务3 用chrome打开dom.sample2.html页面,该页面中内嵌有几个CSS类:.red .green .blue .yellow .thickBorder .seeThrough 在chrome的控制台...

    jquery选择器实例和jar包

    本文将深入探讨jQuery选择器的实例和相关知识,帮助你掌握这一强大的工具。** **1. 元素选择器** 元素选择器基于HTML标签名来选取元素,例如`$("p")`会选择所有的段落元素。通过实例,我们可以看到如何获取并改变...

    jquery选择器的几种用法

    本文将深入探讨jQuery选择器的几种常见用法,帮助你更好地理解和运用这个强大的工具。 1. 基本选择器: jQuery的基本选择器包括ID选择器(`#id`),类选择器(`.class`)和元素选择器(`tag`)。例如,`$("#myID")...

    jQuery 选择器案例.rar

    在这个选择器案例中包含了 3 个基础案例,分别是 呼吸灯特效、手风琴特效、突出展示特效。某些图片可能套用了别人的图片,所有代码是原创。配套与jQuery课程资源。选择器课件详见 ...

    jquery样式选择器插件源码demo

    通过阅读和理解这段源码,开发者不仅可以学习到jQuery选择器的工作原理,还能提升对CSS选择器、DOM操作以及JavaScript性能优化的理解。 总结来说,这个"jquery样式选择器插件"是一个浓缩的精华,它展示了如何用最少...

Global site tag (gtag.js) - Google Analytics