zoukankan      html  css  js  c++  java
  • jQuery之选择器


    层级选择器
      如果两个DOM元素具有祖先后代的关系,就可以用$('ancestor descendant')来选择

      父亲也是祖先
      选择器中的属性选择用中括号括起来[]
      $('ul.lang li.lang-javascript'); // [<li class="lang-javascript">JavaScript</li>]
      $('div.testing li.lang-javascript'); // [<li class="lang-javascript">JavaScript</li>] 
      $('form[name=upload] input');
      多层选择也是允许的:
        $('form.test p input'); // 在form表单选择被<p>包含的<input>
        子选择器(Child Selector)
        父子关系:$('parent>child')

    过滤器(Filter)
      过滤器一般不单独使用,它通常附加在选择器上,帮助我们更精确地定位元素。观察过滤器的效果:
        $('ul.lang li'); // 选出JavaScript、Python和Lua 3个节点
        $('ul.lang li:first-child'); // 仅选出JavaScript
        $('ul.lang li:last-child'); // 仅选出Lua
        $('ul.lang li:nth-child(2)'); // 选出第N个元素,N从1开始
        $('ul.lang li:nth-child(even)'); // 选出序号为偶数的元素
        $('ul.lang li:nth-child(odd)'); // 选出序号为奇数的元素

        $('div:visible'); // 所有可见的div
        $('div:hidden'); // 所有隐藏的div
    表单相关
        针对表单元素,jQuery还有一组特殊的选择器:
        :input:可以选择<input>,<textarea>,<select>和<button>;
        :file:可以选择<input type="file">,和input[type=file]一样;
        :checkbox:可以选择复选框,和input[type=checkbox]一样;
        :radio:可以选择单选框,和input[type=radio]一样;
        :focus:可以选择当前输入焦点的元素,例如把光标放到一个<input>上,用$('input:focus')就可以选出;
        :checked:选择当前勾上的单选框和复选框,用这个选择器可以立刻获得用户选择的项目,如$('input[type=radio]:checked');
        :enabled:可以选择可以正常输入的<input>、<select>等,也就是没有灰掉的输入;
        :disabled:和:enabled正好相反,选择那些不能输入的。

    其他选择器
      此外,jQuery还有很多有用的选择器
        var a = $('.red.green'); // 注意没有空格!节点有多个class,查找同时包含red和green的节点
        $('[name=email]')
        $('[name^=icon]'); // 找出所有name属性值以icon开头的DOM
        $('[name$=with]'); // 找出所有name属性值以with结尾的DOM
        $('input[name=email]');//组合查找
        $('p,div'); // 把<p>和<div>都选出来//多项选择器:多项选择器就是把多个选择器用,组合起来一块选
        $('p.red,p.green'); // 把<p class="red">和<p class="green">都选出来
          注意的是,选出来的元素是按照它们在HTML中出现的顺序排列的,而且不会有重复元素。例如,<p class="red green">不会被上面的$('p.red,p.green')选择两次。

    查找和过滤
      一般情况,选择器可以直接找到目标元素
      但是,当我们先拿到一个祖先jQuery对象后,还可以以这个对象为基准,进行查找和过滤
      最常见的查找是在某个节点的所有子节点中查找,使用find()方法,它本身又接收一个任意的选择器
      <!-- HTML结构 -->
        <ul class="lang">
        <li class="js dy">JavaScript</li>
        <li class="dy">Python</li>
        <li id="swift">Swift</li>
        <li class="dy">Scheme</li>
        <li name="haskell">Haskell</li>
      </ul>

      var ul = $('ul.lang'); // 获得<ul>
      var dy = ul.find('.dy'); // 获得JavaScript, Python, Scheme   find()里面可以传入参数,参数是css选择器
      var swf = ul.find('#swift'); // 获得Swift
      var hsk = ul.find('[name=haskell]'); // 获得Haskell

      如果要从当前节点开始向上查找,使用parent()方法,parent()里面可以传入参数,参数是css选择器
      var swf = $('#swift'); // 获得Swift
      var parent = swf.parent(); // 获得Swift的上层节点<ul>
      var a = swf.parent('.red'); // 获得Swift的上层节点<ul>,同时传入过滤条件。如果ul不符合条件,返回空jQuery对象

      对于位于同一层级的节点,可以通过next()和prev()方法,next()和prev()里面可以传入参数,参数是css选择器
      var swift = $('#swift');
      swift.next(); // Scheme
      swift.next('[name=haskell]'); // 空的jQuery对象,因为Swift的下一个元素Scheme不符合条件[name=haskell]

      swift.prev(); // Python
      swift.prev('.dy'); // Python,因为Python同时符合过滤器条件.dy

    过滤
      jQuery对象就是一个DOM对象数组
      filter()里面可以传入参数,参数是css选择器或函数,返回结果是符合条件的传入的参数
      var langs = $('ul.lang li');
      var a = langs.filter('.dy');
      或者传入一个函数,要特别注意函数内部的this被绑定为DOM对象,不是jQuery对象:
      var langs = $('ul.lang li');
      langs.filter(function () {
        return this.innerHTML.indexOf('S') === 0; // 返回S开头的节点
      });

    map()里面可以传入参数,参数:是函数 ,返回值是函数的返回值
      var langs = $('ul.lang li');
      var arr = langs.map(function () {
        return this.innerHTML;
      }).get(); // 用get()拿到包含string的Array:['JavaScript', 'Python', 'Swift', 'Scheme', 'Haskell']

    此外,jQuery对象如果包含多个DOM对象,first()、last()和slice()方法返回一个新的jQuery对象,把不需要的DOM节点去掉:
      var langs = $('ul.lang li'); // 拿到JavaScript, Python, Swift, Scheme和Haskell
      var js = langs.first(); // JavaScript,相当于$('ul.lang li:first-child')
      var haskell = langs.last(); // Haskell, 相当于$('ul.lang li:last-child')
      var sub = langs.slice(2, 4); // Swift, Scheme, 参数和数组的slice()方法一致

  • 相关阅读:
    二分 || UOJ 148 跳石头
    等边n边型
    激光样式
    n个数中选k个数和为sum
    引爆炸弹
    光盘行动
    (二分)分蛋糕问题
    总结
    个人测试
    第三次团队作业
  • 原文地址:https://www.cnblogs.com/xuanjian-91/p/10320937.html
Copyright © 2011-2022 走看看