jquery之选择器

xuanjian-91 xuanjian-91     2023-02-28     596

关键词:


层级选择器
  如果两个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()方法一致




















































































javascript之jquery-2jquery选择器(jquery选择器基本选择器层次选择器过滤选择器表单选择器)

一、jQuery选择器 jQuery选择器简介 -jQuery选择器类似于CSS选择(定位元素,施加样式),能够实现定位元素,施加行为 -使用jQuery选择器能够将内容与行为分离 -学会使用选择器是学习jQuery的基础jQuery选择器的优势 -... 查看详情

jquery选择器之基本筛选选择

1.基本选择器 2.内容筛选选择器 3.可见性筛选选择器4.属性筛选选择器5.子元素筛选选择器6.表单元素选择器 7.表单对象属性筛选器  查看详情

jquery学习笔记之选择器

  目录:     选择器:                   选择器应用优化 简单的伪类选择器  内容伪类选择器 显隐伪类选择器 子元素伪类选择器 表单对象伪类选择器 表单属性伪类选择器 ... 查看详情

jquery选择器之层级选择器

选择器描述$("parent>child") 子选择器$("ancestordescendant")后代选择器$("prev+next")相邻兄弟选择器$("prev~siblings")一般兄弟选择器子选择器:选择所指定parent元素指定的child的直接子元素。后代选择器:选择给定的祖先元素的所有后代... 查看详情

jquery选择器之过滤选择器

    过滤选择器类似于CSS中的伪类选择器,以冒号开头。过滤选择器根据其过滤规则分为:基本过滤选择器、内容过滤选择器、可见性过滤选择器、属性过滤选择器、子元素过滤选择器、以及表单对象属性过滤选择... 查看详情

锋利的jquery学习笔记之jquery选择器

在介绍jQuery选择器之前,先简单介绍一下CSS选择器--->一、CSS选择器常见的CSS选择器有以下几种:选择器语法描述示例标签选择器E{CSS规则}以文档元素为选择符td{font-size:10px;}a{tetx-decoration:none;}ID选择器#ID{CSS规则}以文档元素的唯... 查看详情

jquery选择器之基本选择器

获得页面各种元素节点1.$(#id属性值)$(‘#useremail‘).css(‘color‘,‘red‘);2. $(tag标签名称)$(‘h2‘).css(‘backgroundColor‘,‘pink‘);$(‘input‘).css(‘backgroundColor‘,‘lightblue‘);3.$(.class属性值)$(‘.pear‘).css(‘fontSize‘,‘3 查看详情

jquery选择器之元素选择器

元素选择器:根据给定(html)标记名称选择所有的元素。描述:$(‘element‘)搜索指定元素标签名的所有节点,这是一个合集的操作。同样的也有原生方法getElementsByTagName()函数支持。第一组:通过getElementsByTagName方法得到页面所... 查看详情

jquery之过滤选择器

过滤选择器  1.基本选择器  2.内容选择器  3.可见性选择器  4.子元素过滤器 过滤选择器简称:过滤器。它其实也是一种选择器,而这种选择器类似于CSS3(http://t.mb5u.com/css3/)里的伪类,可以让不支持CSS3的浏览器也能支... 查看详情

jquery之基本选择器(代码片段)

1.是什么?-有特定格式的字符串2.作用-用来查找特定页面元素3.基本选择器-#id:id选择器-element:元素选择器-.class:属性选择器-*:任意标签-selector1,selector2,selectorN:取多个选择器的并集(组合选择器)-selector1selector2selectorN:取多个选择器的... 查看详情

jquery选择器之属性选择器

  [attribute] 匹配指定属性名的所有元素  [attribute=value]匹配给定的属性名是某个特定值的属性  [attribute!=value] 匹配给定的属性名不是某个特定值的属性  [attribute^=value]以开头  [attribute$=value]以结尾  [attribue*=... 查看详情

jquery选择器之层级选择器

<!DOCTYPEhtml><html><head><metahttp-equiv="Content-type"content="text/html;charset=utf-8"/><title></title><linkrel="stylesheet"href="imooc.css"type="text/css"> 查看详情

jquery选择器之层级选择器

<!DOCTYPEhtml><html><head><metahttp-equiv="Content-type"content="text/html;charset=utf-8"/><title></title><linkrel="stylesheet"href="imooc.css"type="text/css"> 查看详情

jquery选择器之元素选择器

<!DOCTYPEhtml><html><head><metahttp-equiv="Content-type"content="text/html;charset=utf-8"/><title></title><style>div{width:100px;height:90px;float:left;paddin 查看详情

jquery选择器之内容选择器

HTML示例代码<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title></title></head><body><!--HTML区域--><h1>第一个标题</h1><divclass="n 查看详情

jquery选择器之属性筛选选择器

在这么多属性选择器中[attr="value"]和[attr*="value"]是最实用的[attr="value"]能帮我们定位不同类型的元素,特别是表单form元素的操作,比如说input[type="text"],input[type="checkbox"]等[attr*="value"]能在网站中帮助我们匹配不同类型的文件<!DOC... 查看详情

jquery选择器之表单元素选择器

<!DOCTYPEhtml><html><head><metahttp-equiv="Content-type"content="text/html;charset=utf-8"/><title></title><linkrel="stylesheet"href="imooc.css"type="text/css"> 查看详情

深入学习jquery选择器系列第四篇——过滤选择器之属性选择器

×目录[1]简单属性[2]具体属性[3]条件属性前面的话  属性过滤选择器的过滤规则是通过元素的属性来获取相应的元素,对应于CSS中的属性选择器。属性过滤选择器可分为简单属性选择器、具体属性选择器和条件属性选择器... 查看详情