jQuery 选择器与隐式迭代

简介: jQuery 选择器与隐式迭代

      我们在学HTML基础时就学过了各种 CSS 选择器,有id选择器,类选择器,标签选择器,子代选择器,后代选择器,交集选择器,并集选择器,伪类选择器,结构伪类选择器 等等。以及在原生 JS 中我们学到的获取元素的种种方法。


在我们的jQuery,也有很多选择器来获取元素,并且做了统一获取标准的封装


目录:


            一: jQuery 基础选择器:


                  两个例子


             二: jQuery 筛选选择器:


                   两个例子


              三:隐式迭代:


                            隐式迭代使所有 li 变色案例:


jQuery 基础选择器:

基本格式: $ (' css选择器 ')


名称 用法 描述

通配符选择器 $(' * ') 获取所有元素

标签选择器 $(' div ') 获取同一类标签的元素

ID选择器 $(' #div ') 获取指定ID的元素

类选择器 $(' .div ') 获取指定类的元素

后代选择器 $(' ul li ') 获取后代中的某一类元素

子代选择器


$(' ul>li ') 获取子代中的某一类元素

交集选择器 $(' li.name ') 获取交集元素

并集选择器 $(' li,p,div ') 获取多个元素

下面举两个例子:

1.获取ul下的li标签,结果为获取到了两个li,存在伪数组中


<body>

<ul>

  <li></li>

  <li></li>

</ul>

 <script>

   console.log($('ul li'));

 </script>

</body>


2.获取所有的标签,页面所有的标签都被存放在了伪数组中


<body>

   <div></div>

   <p></p>

   <ul>

      <li></li>

      <li></li>

   </ul>

   <script>

        console.log($('*'));

   </script>

</body>



jQuery 筛选选择器:

注意:在 jQuery 的筛选选择器中与 css 的结构选择器不同之处在于它的index是从0开始的


语法 用法( 以li元素为例 ) 描述

:first $(' li:first ') 获取第一个li元素

:last $(' li:last ') 获取最后一个li元素

:eq(index) $(' li:eq(1) ') 在获取到的li元素中,索引为1的li,注意索引从0开始

:odd $(' li:odd ') 在获取到的li元素中,选择索引为奇数的li

:even $(' li:even ') 在获取到的li元素中,选择索引为偶数的li

举两个例子:

1.选择索引为奇数的li元素,使其颜色变为绿色(变换样式采用的是jQuery的css方法)


格式:$(' 选择器 ').css(' 属性 ','属性值’')


<body>

   <ul>

      <li></li>

      <li></li>

      <li></li>

      <li></li>

      <li></li>

      <li></li>

      <li></li>

      <li></li>

   </ul>

   <script>

        $('ul li:odd').css('background','green');

   </script>

</body>


因为筛选选择器的索引从0开始,所以得到奇数索引实际上是数量上的偶数位变色




2.使索引为3的li变粉色


<body>

   <ul>

      <li></li>

      <li></li>

      <li></li>

      <li></li>

      <li></li>

      <li></li>

      <li></li>

      <li></li>

   </ul>

   <script>

        $('ul li:eq(3)').css('background','pink');

   </script>

</body>


索引的第三个,因为索引从0开始,所以实际上是数量上的第四个变色




隐式迭代:

如果我们获取了所有的 li,并且设置其为粉色: $('ul li').css('background','pink'),你会发现,所有的 li 都变了粉色,如图所示。


可是这时候我们会想,我们并没有用for循环给每个li设置粉色啊?为什么全部都变了粉色呢?,这就是 jQuery 的隐式迭代


隐式迭代:遍历以伪数组形式存储的内部DOM元素的过程就叫做隐式迭代,它给匹配到的所有元素进行遍历,并给每个元素添加相应的方法


<body>

   <ul>

      <li></li>

      <li></li>

      <li></li>

      <li></li>

      <li></li>

      <li></li>

      <li></li>

      <li></li>

   </ul>

   <script>

        $('ul li').css('background','pink');

   </script>

</body>




       相比较原生 JS ,jQuery 的隐式迭代更为方便,我们在要使所有获取到的标签变为同一样式时可以使开发更为敏捷


相关文章
N..
|
5月前
|
JavaScript 前端开发 开发者
jQuery选择器
jQuery选择器
N..
41 1
|
13天前
|
JavaScript 前端开发
jQuery 选择器
jQuery 选择器
27 2
|
1月前
|
JavaScript 索引
jQuery 选择器
jQuery 选择器
37 5
|
4月前
|
JavaScript 前端开发
jQuery 选择器
jQuery 选择器
31 0
|
4月前
|
JavaScript 前端开发 索引
jQuery的选择器与自带函数详解
jQuery的选择器与自带函数详解
|
1月前
|
JavaScript 前端开发 CDN
jQuery学习记录--jQuery语法,选择器,事件及hide(),show(), toggle()
本文是关于jQuery的学习笔记,涵盖了jQuery的简介、语法、选择器、事件处理以及hide()、show()、toggle()等方法的使用。
jQuery学习记录--jQuery语法,选择器,事件及hide(),show(), toggle()
|
1月前
|
JavaScript
jQuery 选择器
jQuery 选择器
23 3
|
1月前
|
JavaScript 索引
jQuery 选择器
jQuery 选择器
26 1
|
2月前
|
JavaScript 索引
jQuery的选择器有几种?
jQuery的选择器有几种?
33 1
|
5月前
|
JavaScript 前端开发 搜索推荐
JQuery EasyUI -- 日历选择器,2024年最新程序员经验分享
JQuery EasyUI -- 日历选择器,2024年最新程序员经验分享