• JQuery选择器总结


    下周的项目应该又要做前台的东西,把JQuery的选择器查询并总结一下,一来加深印象,二来可以作为以后查询.

    1.常用的选择器:

    $("#idchoose")               选择一个id为idchoose的元素.

    $(".class")                   选择一个class样式为class的元素.

    $("input[name='person']")          选择一个name为person的input框.

    $("h4:contains('John')")              选择一个包含"John"的h4标题元素.

    $("*")                   选择文档中的所有的元素

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

    $("p#demo") 选取所有 id="demo" 的 <p> 元素。

    $(".title,.item")选取所有class为title和class为item的元素

      通常情况为了防止因为自己思考有误而导致选择器出错,最简单直接的方法就是在html页面的元素上插入一个id然后用id选择器来进行选择.虽然class选择器也可以做到唯一选择,但是考虑的美工大大们可能修改class,所以相比之下还是id选择器比较靠谱一点.

      不过一个页面的id选择器是唯一的,当你有两个或者更多的同名id的时候,只会默认选择第一个该id的元素,所以id选择器不能用来进行批量选择,所以需要批量选择的时候(比如把页面内的所有的输入框都设置成readonly),显然需要使用$("input[type='text']")这种有过滤的元素选择器来完成的.当然clss也可以用来进行批量选择,同样的,考虑的前台还有美工大大们的活,就不要用class选择器了,万一发生了误删或者样式名字改变这种悲剧的事情,会很伤心的.

    下面是一些JQuery选择器的分类总结:

    总结大部分参考前辈快乐的langYa的博文以及W3C的JQuery教程,链接见文章最后.

    元素选择器:

    $("p")           选择所有的<p>元素

    通常情况下,元素选择器都是与过滤选择器一起结合使用的,如:$("p:[type='hidden']"),选择tpye属性为hidden的所有<p>元素.
    注释

     层叠选择器:

    $("form input")         选择所有的form元素中的input元素 

    $("#main > *")          选择id值为main的所有的子元素 

    //这个选择器与$("#main").children()所达成的效果是一样的,所以在选择元素的时候并不一定要通过选择器来完成,灵活的使用祖先和后代遍历一样也可以完成查找功能.
    注释

    /* $("label + input")     选择所有的label元素的下一个input元素节点,经测试选择器返回的是label标签后面直接跟一个input标签的所有input标签元素 */ 

    模仿这个选择器写了一个demo,但是并没有出现预想到的结果(貌似啥都没有选到),时间关系暂时不去研究了,以后有空在验证一下.
    注释

     $("#prev ~ div")       同胞选择器,该选择器返回的为id为prev的标签元素的所有的属于同一个父元素的div标签  

    //同样的 我们也可以利用同胞遍历来完成这个能:$("#prev").siblings("div"); 虽然并不知道这两种方式哪一种的性能比较好一点,只是多提供一种选择.
    注释

     基本过滤选择器: 

    $("tr:first")               选择所有tr元素的第一个 

    $("tr:last")                选择所有tr元素的最后一个 

    $("input:not(:checked) + span")  过滤掉:checked的选择器的所有的input元素//不太了解什么这是一个什么场景

    $("tr:even")               选择所有的tr元素的第0,2,4... ...个元素(注意:因为所选择的多个元素时为数组,所以序号是从0开始)

    $("tr:odd")                选择所有的tr元素的第1,3,5... ...个元素 

    $("td:eq(2)")             选择所有的td元素中序号为2的那个td元素 

    $("td:gt(4)")             选择td元素中序号大于4的所有td元素 

    $("td:lt(4)")              选择td元素中序号小于4的所有的td元素 

    $(":header")            选择h1、h2、h3之类的  

    $("div:animated")     选择正在执行动画效果的元素 

    内容过滤选择器:

    $("div:contains('John')") 选择所有div中含有John文本的元素

    这只是一个例子,contains(text)是一个比较常用的过滤选择器,但是在实际的应用过程中应该尽量避免直接使用元素选择器来搭配contain(text),比如有这样一段代码:
    <div id="form">
       <p>主div</p>
         <div id="second">
                 <p>我是第二层<p>
                 <div id="goal">
                        <p>我是要被找到的目标</p>
                 </div
         </div>
     </div>  

    如果我们想选择选择id为goal的那个div,如果使用$("div:contains('目标')") ,那么三个div层都会被选中,以为外层的连个div也嵌套的id为goal的div以及他的内容,所以外层的两个div也包含了文本"目标",他们也会被选中,所以在这种情况下使用最好能够唯一选择的选择器来配合contains(text)完成条件过滤                            //

    $("td:empty")           选择所有的为空(也不包括文本节点)的td元素的数组 

    $("div:has(p)")        选择所有含有p标签的div元素 

    $("td:parent")          选择所有的以td为父节点的元素数组

    可视化过滤选择器

    $("div:hidden")        选择所有的被hidden的div元素 

    $("div:visible")        选择所有的可视化的div元素 

    属性过滤选择器:

    $("div[id]")              选择所有含有id属性的div元素 

    $("input[name='newsletter']")    选择所有的name属性等于'newsletter'的input元素  

      //在日常工作中,因为input是一个非常常用的一个标签,它的name属性通常因为要与后台相对应经常是唯一的,所以经常用$("input[name='newsletter']")这种形式做唯一选择.用input的type属性,$("input[type='text']"),做批量选择.
    注释

    $("input[name!='newsletter']") 选择所有的name属性不等于'newsletter'的input元素

    $("input[name^='news']")         选择所有的name属性以'news'开头的input元素 

    $("input[name$='news']")         选择所有的name属性以'news'结尾的input元素 

    $("input[name*='man']")          选择所有的name属性包含'news'的input元素

    $("input[id][name$='man']")    可以使用多个属性进行联合选择,该选择器是得到所有的含有id属性并且那么属性以man结尾的元素;

    子元素过滤选择器:

    $("ul li:nth-child(2)"),$("ul li:nth-child(odd)"),$("ul li:nth-child(3n + 1)")

    $("div span:first-child")          返回所有的div元素的第一个子节点的数组

    这里使用$("div span").first()会简洁一点.另外,子元素选择器的选择只限于在子元素中,但是当需要对孙元素进行操作的时候,使用子元素过滤器就会产生错误的选择,错误例子暂时先不例举了,这时候正确的写法应当是$("div").find("span").first()

    $("div span:last-child")           返回所有的div元素的最后一个节点的数组      //同样的,$(div span).last()

    $("div button:only-child")       返回所有的div中只有唯一一个子节点的所有子节点的数组

    表单元素选择器:

    $(":input")                  选择所有的表单输入元素,包括input, textarea, select 和 button

    $(":text")                     选择所有的text input元素 

    $(":password")           选择所有的password input元素 

    $(":radio")                   选择所有的radio input元素 

    $(":checkbox")            选择所有的checkbox input元素 

    $(":submit")               选择所有的submit input元素 

    $(":image")                 选择所有的image input元素 

    $(":reset")                   选择所有的reset input元素 

    $(":button")                选择所有的button input元素 

    $(":file")                     选择所有的file input元素 

    $(":hidden")               选择所有类型为hidden的input元素或表单的隐藏域

    表单元素过滤选择器:

    $(":enabled")             选择所有的可操作的表单元素 

    $(":disabled")            选择所有的不可操作的表单元素 

    $(":checked")            选择所有的被checked的表单元素 

    $("select option:selected") 选择所有的select 的子元素中被selected的元素

    JQuery选择器大全原文地址:http://www.cnblogs.com/hulang/archive/2011/01/12/1933771.html

  • 相关阅读:
    Azureus 3.0.0.8
    KchmViewer 3.0
    GNOME 2.18.0 正式版颁发宣布
    Emacs 22.0.95
    gTwitter:Twitter 的 Linux 客户端
    KDE DVD Authoring Wizard-易用的 DVD 制造器材
    GIMP 2.3.15
    Monit-零碎看监工具
    Cobras-专注于 Qt 的 IDE
    K3b 1.0 正式版公布
  • 原文地址:https://www.cnblogs.com/bigbearche/p/4824905.html
Copyright © 2020-2023  润新知