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()方法一致

原文地址:https://www.cnblogs.com/xuanjian-91/p/10320937.html