zoukankan      html  css  js  c++  java
  • HTML 学习笔记 JQuery(选择器)

    学习前端也有一段时间了,今天终于进入到JQuery阶段了,对于新手来讲,JQuery的选择器类型之多 功能之强大实在不是一天两天能够记得完的。现在,就采用边学边记录的方式。以后要是忘了的话,也有一个地方能够迅速找到。今天也是站在前辈大神的肩膀上学习JQuery。

    1.属性选择器

    属性选择器的语法

    jQuery( "[attribute|='value']" )
    
    attribute: 一个属性名.
    
    value: 一个属性值,引号是可选的. 可以是一个不带引号的一个单词或带一个引号的字符串。

    实例:

    <html>
        <head>
            <meta charset="UTF-8">
            <title></title>
            <script src="../js/jquery-2.1.1.min.js"></script>
            <!--<script src="../js/selector.js"></script>-->
            <style>
                a{
                    display: block;
                    
                }
            </style>
        </head>
        <body>
            <a href="#" hreflang="en">Some text</a>
            <a href="#" hreflang="en-UK">Some other text</a>
              <a href="#" hreflang="english">will not be outlined</a>
              <script>
                  
                  $("a[hreflang = 'en']").css("background","red");
                  $("a[hreflang |='en']").css("border","1px solid red");
              </script>
        </body>
    </html>

    和CSS选择器一样 属性选择器也有多种多样的根据属性值查找元素的写法。下图就是不同的查找属性值的选择器写法

    2.基础选择器

    2.1 all Selector

    选择所有的元素

    语法

    jQuery( "*" )

    注意:除非被它自己使用,否则"*"选择器或通用选择器,其速度是极慢的。

    例子:

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <title></title>
            <script src="../js/jquery-2.1.1.min.js"></script>
            <style type="text/css">
                div,span,p {
                    width: 80px;
                    text-align: center;
                    height: 40px;
                    float: left;
                    margin: 15px;
                    padding: 10px;
                    background-color: #eeeeee;
                }
            </style>
        </head>
        <body>
            <div>DIV</div>
            <span>SPAN</span>
            <p>P <button>Button</button></p>
            <script>
                var elements = $("*").css("border","1px solid red").length;
                $("body").prepend("<h3>"+ elements + "elements found</h3>")
            </script>
            
        </body>
    </html>

    效果:

    查找一个DIV中的所有元素

    <!DOCTYPE html>
    <html>
    <head>
      <style>
      h3 { margin: 0; }
      div,span,p {
        width: 80px;
        height: 40px;
        float:left;
        padding: 10px;
        margin: 10px;
        background-color: #EEEEEE;
      }
      #test {
        width: auto; height: auto; background-color: transparent;
      }
      </style>
      <script src="http://cdn.bootcss.com/jquery/1.11.2/jquery.min.js"></script>
    </head>
    <body>
      <div id="test">
      <div>DIV</div>
      <span>SPAN</span>
      <p>P <button>Button</button></p>
    </div>
    <script>
    var elementCount = $("#test").find("*").css("border","3px solid red").length;
    $("body").prepend("<h3>" + elementCount + " elements found</h3>");</script>
     
    </body>
    </html>

    效果图

    2.2 类选择器

    选择给定样式类名的所有元素

    语法:

    jQuery( ".class" )
    class: 一个用来查找的类名。一个元素可以有多个类;其中只有一个必须匹配

    对于类选择器,如果浏览器支持,jQuery使用JavaScript的原生getElementsByClassName()函数来实现。

    例子:

    <!DOCTYPE html>
    <html>
    <head>
      <style>
      div,span {
        width: 100px;
        height: 40px;
        float:left;
        padding: 10px;
        margin: 10px;
        background-color: #EEEEEE;
      }
      </style>
      <script src="http://cdn.bootcss.com/jquery/1.11.2/jquery.min.js"></script>
    </head>
    <body>
      <div class="notMe">div class="notMe"</div>
     
      <div class="myClass">div class="myClass"</div>
      <span class="myClass">span class="myClass"</span>
    <script>$(".myClass").css("border","3px solid red");</script>
     
    </body>
    </html>

    效果图

    查找的元素都“的myclass”和“otherclass的的”类。

    <html>
        <head>
            <meta charset="UTF-8">
            <title></title>
            <script src="../js/jquery-2.1.1.min.js"></script>
            <style type="text/css">
                div,span,p {
                    width: 120px;
                    text-align: center;
                    height: 40px;
                    float: left;
                    margin: 15px;
                    padding: 10px;
                    background-color: #eeeeee;
                }
            </style>
        </head>
        <body>
            <!--<div>DIV</div>
            <span>SPAN</span>
            <p>P <button>Button</button></p>-->
            
            <div class="myclass">div class="notMe"</div>
     
              <div class="myclass otherclass">div class="myClass"</div>
              <span class="myclass otherclass">span class="myClass"</span>
            
            <script>
    //            var elements = $("*").css("border","1px solid red").length;
    //            $("body").prepend("<h3>"+ elements + "elements found</h3>")
                $(".myclass.otherclass").css("background-color","red");
            </script>
            
        </body>
    </html>

    2.3元素选择器

    <html>
        <head>
            <meta charset="UTF-8">
            <title></title>
            <script src="../js/jquery-2.1.1.min.js"></script>
            <style type="text/css">
                div,span,p {
                    width: 120px;
                    text-align: center;
                    height: 40px;
                    float: left;
                    margin: 15px;
                    padding: 10px;
                    background-color: #eeeeee;
                }
            </style>
        </head>
        <body>
            <!--<div>DIV</div>
            <span>SPAN</span>
            <p>P <button>Button</button></p>-->
            
            <!--<div class="myclass">div class="notMe"</div>
     
              <div class="myclass otherclass">div class="myClass"</div>
              <span class="myclass otherclass">span class="myClass"</span>-->
              <p id="heihei">哈哈哈哈哈哈</p>
              <p>嘿嘿嘿嘿嘿嘿</p>
              <p>吼吼吼吼吼吼</p>
            
            <script>
    //            var elements = $("*").css("border","1px solid red").length;
    //            $("body").prepend("<h3>"+ elements + "elements found</h3>")
    //            $(".myclass.otherclass").css("background-color","red");
                $("p").css("border","1px solid red");
            </script>    
        </body>
    </html>

    效果:

    2.4 id 选择器

    选择一个具有给定ID属性的单个元素

    语法

    jQuery( "#id" )
    id: 一个用来查找的ID,即元素的id属性。/p>

    对于ID选择,jQuery使用JavaScript函数document.getElementById(),这是非常有效的。当另一个选择是附加到ID选择器,比如h2#pageTitle,在确定作为匹配的元素前,jQuery执行一个额外的检查。

    调用 jQuery() (或 $()) 带上一个选择器作为它的参数,将返回一个jQuery对象包含零个或一个DOM元素的集合。

    每个id值在一个文件中只能使用一次。如果多个元素分配了相同的ID,将只匹配该ID选择集合的第一个DOM元素。但这种行为不应该发生;有超过一个元素的文件使用相同的ID是无效的。

    例子:

    <!DOCTYPE html>
    <html>
    <head>
      <style>
      div {
        width: 90px;
        height: 90px;
        float:left;
        padding: 5px;
        margin: 5px;
        background-color: #EEEEEE;
      }
      </style>
      <script src="http://cdn.bootcss.com/jquery/1.11.2/jquery.min.js"></script>
    </head>
    <body>
      <div id="notMe"><p>id="notMe"</p></div>
     
      <div id="myDiv">id="myDiv"</div>
    <script>$("#myDiv").css("border","3px solid red");</script>
     
    </body>
    </html>

    效果:

    2.5 multiple selector

    将每一个选择器匹配到的元素合并后一起返回。

    语法

    jQuery( "selector1, selector2, selectorN" )

    selector1: 任何有效的选择

    selector2: 其他有效的选择

    selectorN: 更多有效的选择只要你喜欢。

    例子

    <!DOCTYPE html>
    <html>
    <head>
      <style>
     
      div,span,p {
        width: 126px;
        height: 60px;
        float:left;
        padding: 3px;
        margin: 2px;
        background-color: #EEEEEE;
        font-size:14px;
      }
      </style>
      <script src="http://cdn.bootcss.com/jquery/1.11.2/jquery.min.js"></script>
    </head>
    <body>
      <div>div</div>
     
      <p class="myClass">p class="myClass"</p>
      <p class="notMyClass">p class="notMyClass"</p>
      <span>span</span>
    <script>$("div,span,p.myClass").css("border","3px solid red");</script>
     
    </body>
    </html>

    效果:

    其他的一些选择器

    层叠选择器

    $("form input")         选择所有的form元素中的input元素
    $("#main > *")          选择id值为main的所有的子元素
    $("label + input")     选择所有的label元素的下一个input元素节点,经测试选择器返回的是label标签后面直接跟一个input标签的所有input标签元素
    $("#prev ~ div")       同胞选择器,该选择器返回的为id为prev的标签元素的所有的属于同一个父元素的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:ll(4)")              选择td元素中序号小于4的所有的td元素

    更多选择器 请看

    http://www.cnblogs.com/onlys/archive/2010/12/15/1906380.html

  • 相关阅读:
    分割回文串(力扣第131题)
    子集 II(力扣第91题)
    子集(力扣第78题)
    组合总和 III(力扣第216题)
    JavaWeb部分 (前序)
    JavaSE部分 (IO流下)
    JavaSE部分 (IO流上)
    JavaSE部分 (File类)
    Leetcode 08.04 幂集 回溯与位图
    Leetcode 1405 最长快乐字符串 穷举与贪心
  • 原文地址:https://www.cnblogs.com/huanying2000/p/6251675.html
Copyright © 2011-2022 走看看