JQuery选择器(中)

HTML5学堂:在学习JQuery开发的时候,选择器有多种,而我们将接着介绍选择器的其他类型,希望对大家有帮助!

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选择器(上)

原文发布于微信公众号 - HTML5学堂(h5course-com)

原文发表时间:2015-12-23

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Nian糕的私人厨房

JavaScript 基础

JavaScript 是一种轻量级,解释型的,有着函数优先 (First-class Function) 的编程语言,虽然它是作为开发 WEB 页面的脚本语言而...

845
来自专栏柠檬先生

jquery 筛选元素 (3)

.addBack()   添加堆栈中元素集合到当前集合中,一个选择性的过滤选择器。   .addBack([selector]) ...

1667
来自专栏从流域到海域

《笨办法学Python》 第37课手记

《笨办法学Python》 第37课手记 本节课是复习课。关键字是指系统预先定义好的含有特定含义的字符串或者函数,注意你在自定义函数时不能与关键字重名。可是该课中...

16410
来自专栏编程

Python读书笔记4

上期介绍了数字型数据,本期和大家分享的是另一个常见的数据类型字符串,可以简单的理解为Excel中的文本。 Excel在存储内核中其实只有两种:文本、数字;日期归...

1865
来自专栏有趣的Python和你

循环与判断判断循环

832
来自专栏老马寒门IT

06-老马jQuery教程-jQuery高级

jQuery里面的大部分API都是在jQuery的原型对象上定义的。jQuery源码中对原型对象做了简写的处理。也就是说:jQuery.fn === jQuer...

1940
来自专栏企鹅号快讯

Python教学从零开始——第四天

在前面的几天中,我们了解了tulpe,list的操作,os模块案例,for循环,前面的示例比较简单,几乎没有太多的语法,今天我们要来说一法语法,语法通常都是硬性...

1987
来自专栏web前端教室

JavaScript ES6 模板字符串

偶然发现这个新东西,ES6也有模板了,是使用反引号`,来表示的。 这个新东西被称为字符串字面量,就是模板字符串。它使JS也有了简单的字符串插值特性。 为什么说是...

1979
来自专栏liuchengxu

Vim 文本对象指南 (2)

接 Vim 文本对象 (1), 关于插件使用, 可以查看完整配置 space-vim.

392
来自专栏阿凯的Excel

Python读书笔记11(循环遍历所有内容)

前面的文章和大家分享了数字、字符串、列表和元组,我们重新声明这些变量回顾一下! ? 数字、浮点数直接用等号声明 字符串需要将内容用英文单引号或双引号括起来 列...

2788

扫描关注云+社区