jQuery的选择器

$(document).ready(function(){});

$(document(){});简写

//jQuery等待加载 只需等待网页中的DOM结构加载完毕,才能执行包裹的代码,效率更高

window.onload = function(){};  //javaScript等待加载,必须等待网页加载完毕(包括图片)才能执行的包裹代码

一、基本选择器

1.ID选择器

使用公式: $("#id")

使用示例: $("#box")  //获取id属性为box的元素

介绍:ID选择器#id就是利用DOM元素的id属性值来筛选匹配的元素,并以iQuery包装集的形式返回给对象。

2.元素选择器

使用公式:$("element")

使用示例:$(“div”) //获取所有的元素

介绍:元素选择器是根据元素名称匹配相应的元素。元素选择器指向的是DOM元素的标记名,也就是说元素选择器是根据元素的标记名选择的。

3.类名选择器

使用公式:$(".class")

使用示例:$(".box") //获取class属性值为box的所有元素

介绍:类选择器是通过元素拥有的CSS类的名称查找匹配的DOM元素。在一个页面中,一个元素可以有多个CSS类,一个CSS类又可以匹配多个元素,如果有元素中有一个匹配类的名称就可以被类选择器选取到。简单地说类名选择器就是以元素具有的CSS类名称查找匹配的元素。

4.复合选择器

使用公式:$("selector1,selector2,......,selectorN")

使用示例:$("div,#btn")    //要查询文档中的全部的<div>元素和id属性为btn的元素

selector1:一个有效的选择器,可以是ID选择器、元素选择器或类名选择器等

selector2:另一个有效的选择器,可以是ID选择器、元素选择器或类名选择器等

selectorN:(可选择)任意多个选择器,可以是ID选择器、元素选择器或类名选择器等

介绍: 复合选择器将多个选择器(可以是ID选择器、元素选择器或是类名选择器)组合在一起,两个选择器之间以逗号","分隔,只要符合其中的任何一个筛选条件就会被匹配,返回的是一个集合形式的jQuery包装集,利用jQuery索引器可以取得集合中的jQuery对象。

注意:多种匹配条件的选择器并不是匹配同时满足这几个选择器的匹配条件的元素,而是将每个匹配的元素合并后一起返回。

5.通配符选择器

  $(" * ") //取得页面上所有的DOM元素集合的jQuery包装集

二、层次选择器

1.ancestor descendant选择器

使用公式:$("ancestor descendant")

使用示例:$(" ul li") //匹配ul元素下的全部li元素

ancestor是指任何有效的选择器。

descendant是用以匹配元素的选择器,并且ancestor所指定元素后代元素。

ancestor descendant选择器中ancestor代表祖先,descendant代表子孙,用于在给定的祖先元素下匹配所有的后代元素

2.parent>child选择器

 使用公式:$(" parent>child")

 使用示例:$(" form>input") //匹配表单中所有的子元素input

 parent是指任何有效的选择器

 child使用以匹配元素的选择器,并且它是parent元素的子元素

  介绍:parent>child选择器中的parent代表父元素,child代表子元素,用于在给定的父元素下匹配所有的子元素,使用该选择器只能选择器父元素的子元素

3.prev+next选择器

使用公式:$(" prev+next")

使用示例:$("div+img") // 匹配<div>标签后的<img>标记

prev是指任何有效的选择器

next是一个有效选择器并紧接着prev选择器

介绍:pev+next选择器用于匹配所有紧接在prev元素后的next元素,其中,prev和next是两个相同级别的元素


4.prev~siblings选择器

使用公式:$("prev~siblings")

prev是指任何有效的选择器

介绍:prev~siblings选择器用于匹配prev元素之后的所有siblings元素,其中prev和siblings是个相同辈元素


三、过滤选择器

1.简单过滤器

简单过滤器是指冒号开头的,通常用于实现简单过滤效果的过滤器

:frist

           说明:匹配找到第一个元素,它是与选择器结合使用的

            示例:$(" tr:frist ")  //匹配表格的第一行

:last

            说明:匹配找到最后一个元素,它是与选择器结合使用的

            示例:$(" tr:last ")  //匹配表格的最后一行

:even

            说明:匹配所有索引值为偶数的元素,索引值从0开始计算

           示例:$(" tr:even")  //匹配索引为偶数一行

:odd

              说明:匹配所有索引值为奇数的元素,索引值从0开始计数

              示例:$("tr:odd")       //匹配索引值为奇数的行

:eq(index)

                说明:匹配一个给定索引值的元素

                示例:$("div:eq(1)")      //匹配第二个div元素

:gt(index)

                说明:匹配所有大于给定索引值的元素

                示例:$("span:gt(0)")       //匹配索引大于0的span元素(注:大于0,而不包括0)

:lt(index)

                说明:匹配所有小于给定索引值的元素

                示例:$("div:lt(2)")     //匹配索引小于2的div元素(注:小于2,而不包括2)

:header

                说明:匹配h1,h2,h3......之类的标题元素

                示例:$(".cls:header")      //匹配全部类名为cls的标题元素,如果":"前不写则匹配所有的标题元素

:not(selector)

                说明:去除所有给定选择器匹配的元素

                示例:$("input:not(:checked)")         //匹配没有被选中的input元素

animated

                说明:匹配所有正在执行动画效果的元素

                示例:$("div:animated")          //匹配正在执行的动画的div元素

2.内容过滤器

            内容过滤器就是通过DOM元素包含的文本内容以及是否含有匹配的元素进行筛选

:contains(text)

                说明:匹配包含给定文本的元素

                示例:$("li:contains('word')")      //匹配含有"word"文本内容的元素

:empty

                说明:匹配所有不包含子元素或者文本的空元素

                示例:$("td:empty")        //匹配不包含子元素或者文本的单元格

:has(selector)

                说明:匹配含有选择器所匹配元素的元素

                示例:$("td:has(p)")           //匹配表格的单元格中还有<p>标记的单元格

:parent

                说明:匹配含有子元素或者文本的元素

                示例:$("td:parent")      //匹配不为空的单元格,即在该单元格中还包括子元素或则文本

3.可见性过滤器

            元素的可见状态有两种,分别是隐藏状态和显示状态。可见性过滤器就是利用元素的可见状态匹配元素的

:visible

                说明:匹配所有可见元素

:hidden

                说明:匹配所有不可见元素

                注意:在应用:hidden过滤器时,display属性是none以及input元素的type属性为hidden的元素都会被匹配识别

4.表单对象的属性过滤器

            表单对象的属性过滤器通过表单元素的状态属性(例如:选中、不可用等状态)匹配元素

:checked

                说明:匹配所有选中的被选中元素

                示例:$("input:checked")            //匹配所有被选中的input元素

:disabled

                说明:匹配所有不可用元素

                示例:$("input:disenabled")           //匹配所有不可用input元素

:enabled

                说明:匹配所有可用的元素

                示例:$("input:enabled")         //匹配所有可用的input元素

:selected

                说明:匹配所有选中的option元素

                示例:$("select option:selected")            //匹配所有被选中的选项元素

5.子元素过滤器

            子元素选择器就是筛选给定某个元素的子元素,具体的过滤条件由选择器的种类而定

:first-child

                说明:匹配所有给定元素的第一个子元素

                示例:$("ul  li:first-child")            //匹配ul元素中的第一个子元素li

:last-child

                说明:匹配所有给定元素的最后一个子元素

                示例:$("ul  li:last-child")            //匹配ul元素中的最后一个子元素li

:only-child

                说明:如果某个元素是它父元素中唯一的子元素,那么将会被匹配,如果父元素中含有其他元素,则不会被匹配

                示例:$("ul  li:only-child")            //匹配只含有一个li元素的ul元素中的li

:nth-child(index/even/odd/equation)

                说明:匹配可每个父元素下的第index个子或奇偶元素,index从1开始,而不是从0开始

                示例:$("ul li :nth-child(even)")           //匹配ul中索引值为偶数的li元素

                $("ul li:nth-child(3)")              //匹配ul中第3个li元素

四、属性选择器

        属性选择器就是通过元素的属性作为过滤条件进行筛选对象

        [attribute]

            说明:匹配包含给定属性的元素

            示例:$("div[name]")       //匹配包含有name属性的div元素

        [attribute=value]

            说明:匹配属性值为value的元素

            示例:$("div[name='test']")           //匹配name属性是test的div元素

        [attribute!=value]

            说明:匹配属性值不等于value的元素

            示例:$("div[name!='test']")         //匹配name属性不是test的div元素

        [attribute*=value]

            说明:匹配属性值含有value的元素

            示例:$("div[name*="test"]")         //匹配name属性值中含有test值的div元素

        [attribute^=value]

            说明:匹配属性值以value开始的元素

            示例:$("div[name^='test']")         //匹配name属性以test开头的div元素

        [attribute$=value]

            说明:匹配属性值以value结束的元素

            示例:$("div[name$='test']")         //匹配name属性以test结尾的div元素

        [selector1][selector2][selectorN]

            说明:复合属性选择器,需要同时满足多个条件时使用

            示例:$("div[id][name^='test']")            //匹配具有id属性并且name属性是以test开头的div元素

    五、表单选择器

表单选择器是匹配经常在表单内出现的元素。但是匹配的元素不一定在表单中

:input

            说明:匹配所有的input元素

            示例:

                 $(":input")        //匹配所有的input元素

                 $("form :input")         //匹配<form>标记中的所有input元素,需要注意,在form和冒号之间有一个空格

:button

            说明:匹配所有的普通按钮,即type="button"的input元素

            示例:$(".button")             //匹配所有普通按钮

:checkbox

            说明:匹配所有的复选框

            示例:$(":checkbox")           //匹配所有的复选框

:file

            说明:匹配所有的文件域

            示例:$(":file")             //匹配所有的文件域

:hidden

            说明:匹配所有的不可见元素,或者type为hidden的元素

            示例:$(":hidden")         //匹配所有的隐藏域

:image

            说明:匹配所有的图像域

            示例:$(":image")            //匹配所有的图像域

:password

            说明:匹配所有的密码域

            示例:$(":password")            //匹配所有的密码域

:radio

            说明:匹配所有的单选按钮

            示例:$(":radio")            //匹配所有的单选按钮

:reset

            说明:匹配所有的重置按钮,即type="reset"的input元素

            示例:$(":reset")          //匹配所有的重置按钮

:submit

            说明:匹配所有的提交按钮,即type="submit"的input元素

            示例:$(":submit")            //匹配所有的提交按钮

:text

            说明:匹配所有的单行文本框

            示例:$(".text")           //匹配所有的单行文本框


选择器中注意事项

 1.选择器中含有特殊符号的注意事项

            含有"."、"#"、"{"、"}"等特殊字符:根据W3C规定,属性值中是不能包含这些特殊字符的,但在实际的项目中偶尔会遇到这种表达式中含有"#"和"}"等特殊字符的情况。这时,如果按照普通方法去处理的话就会出现错误,解决这类错误的方法是使用转义符号将其转义。

<div id="li#db">liaidb</div>

<div id="lidb(1)">lilovedb</div>

如果按照普通方式来获取,例如:

$("#li#db");

$("#lilovedb(1)");

这样是不能正确获取到元素的,正确的写法如下:

$("#li\\#db");

$("#lilovedb\\(1\\)");

 2.属性选择器的@符号问题:

在jQuery升级版本过程中,jQuery在1.3.1版本中彻底放弃了1.1.0版本遗留的@符号,假如我们使用1.3.1以上的版本,那么不需要在属性前添加@符号

$("div[@name="lidb"]");

正确写法是将@符号去掉,即改为如下形式:

$("div[name="lidb"]");

        选择器中空格的注意事项

            在实际应用当中,选择器中含有空格也是不容忽视的,多一个空格或则少一个空格也会得到截然不同的结果。

    <div class="name">

        <div style="display: none;">小李</div>

        <div style="display: none;">小王</div>

        <div style="display: none;">小明</div>

        <div style="display: none;" class=name>小张</div>

    </div>

    <div style="display: none;" class=name>小玉</div>

    <div style="display: none;" class=name>小刘</div>


    使用如下的jQuery选择器分别获取它们

    <script type="text/javascript">

        var $a=$(".name :hidden");

        var $b=$(".name:hidden");

        console.log($a)

        console.log($b)

    </script>


版权声明:版权声明:本文为博主原创文章,转载请注明网址,谢谢 https://blog.csdn.net/Chenftli/article/details/81588447

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,923评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,154评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,775评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,960评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,976评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,972评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,893评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,709评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,159评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,400评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,552评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,265评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,876评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,528评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,701评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,552评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,451评论 2 352

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,747评论 1 92
  • 选择器的意义就是将众多html代码中准确的找出我们想找的单元。接下来将常见的选择器以及作用列举出来。 基本选择器 ...
    布尔教育阅读 128评论 0 0
  • 1. 基本选择器  基本选择器是JQuery最常用的选择器,也是最简单的选择器,它通过元素id、class和标签名...
    小伟_be27阅读 3,440评论 0 1
  • 第一章 入门 基本功能:访问和操作 dom 元素,控制页面样式,对页面的事件处理,与ajax完美结合,有丰富的插件...
    X_Arts阅读 1,045评论 0 2
  • HTML 5 HTML5概述 因特网上的信息是以网页的形式展示给用户的,因此网页是网络信息传递的载体。网页文件是用...
    阿啊阿吖丁阅读 3,887评论 0 0