jQuery 元素操做

jQuery 元素操做主要讲的是用jQuery方法,操做标签的遍历、建立、添加、删除等操做。css

1、 遍历元素

jQuery 隐式迭代是对同一类元素作了一样的操做。 若是想要给同一类元素作不一样操做,就须要用到遍历。html

语法1app

 

 

注意:此方法用于遍历 jQuery 对象中的每一项,回调函数中元素为 DOM 对象,想要使用 jQuery 方法须要转换。dom

语法2函数

 

 

注意:此方法用于遍历 jQuery 对象中的每一项,回调函数中元素为 DOM 对象,想要使用 jQuery 方法须要转换。this

演示代码atom

<body>
   <div>1</div>
   <div>2</div>
   <div>3</div>
   <script>
       $(function() {
           // 若是针对于同一类元素作不一样操做,须要用到遍历元素(相似for,可是比for强大)
           var sum = 0;
           var arr = ["red", "green", "blue"];
           // 1. each() 方法遍历元素
           $("div").each(function(i, domEle) {
               // 回调函数第一个参数必定是索引号 能够本身指定索引号号名称
               // console.log(i);
               // 回调函数第二个参数必定是 dom 元素对象,也是本身命名
               // console.log(domEle); // 使用jQuery方法须要转换 $(domEle)
               $(domEle).css("color", arr[i]);
               sum += parseInt($(domEle).text());
          })
           console.log(sum);
           // 2. $.each() 方法遍历元素 主要用于遍历数据,处理数据
           // $.each($("div"), function(i, ele) {
           //     console.log(i);
           //     console.log(ele);
           // });
           // $.each(arr, function(i, ele) {
           //     console.log(i);
           //     console.log(ele);
           // })
           $.each({
               name: "andy",
               age: 18
          }, function(i, ele) {
               console.log(i); // 输出的是 name age 属性名
               console.log(ele); // 输出的是 andy 18 属性值
          })
      })
   </script>
</body>

2、 案例:购物车案例模块-计算总计和总额

  1. 把全部文本框中的值相加就是总额数量,总计同理。spa

  2. 文本框里面的值不一样,若是想要相加须要用 each() 遍历,声明一个变量作计数器,累加便可。htm

  3. 点击+号-号,会改变总计和总额,若是用户修改了文本框里面的值一样会改变总计和总额对象

  4. 所以能够封装一个函数求总计和总额,以上2个操做调用这个函数便可.

  5. 注意 :总计是文本框里面的值相加用val() ,总额是普通元素的内容用text()

  6. 要注意普通元素里面的内容要去掉¥而且转换为数字型才能相加

 

 // 封装一个函数
   function getSum() {
       var count = 0; //总数
       var money = 0; //总额
       $(".itxt").each(function (i, ele) {
           //遍历每一个商品的数量 相加 赋值给总计
           count += parseInt($(ele).val());
           $(".amount-sum em").text(count);
      });
       $(".p-sum").each(function (i, ele) {
           // 遍历每一个商品小计 相加 赋值给总额 substr(1)去掉¥ toFixed(2)取两位小数
           money += parseFloat($(ele).text().substr(1));
           $(".price-sum em").text("¥" + money.toFixed(2));
      })
  }

 

3、 建立、添加、删除

jQuery方法操做元素的建立、添加、删除方法不少,咱们重点使用部分,以下:

语法总和

 

 

 

 

 

 

 

 

注意:以上只是元素的建立、添加、删除方法的经常使用方法,其余方法请参详API。

案例代码

<body>
   <ul>
       <li>原先的li</li>
   </ul>
   <div class="test">我是原先的div</div>
   <script>
       $(function() {
           // 1. 建立元素
           var li = $("<li>我是后来建立的li</li>");
     
           // 2. 添加元素
           // 2.1 内部添加
           // $("ul").append(li); 内部添加而且放到内容的最后面
           $("ul").prepend(li); // 内部添加而且放到内容的最前面
           // 2.2 外部添加
           var div = $("<div>我是后妈生的</div>");
           // $(".test").after(div);
           $(".test").before(div);
     
           // 3. 删除元素
           // $("ul").remove(); 能够删除匹配的元素 自杀
           // $("ul").empty(); // 能够删除匹配的元素里面的子节点 孩子
           $("ul").html(""); // 能够删除匹配的元素里面的子节点 孩子
      })
   </script>
</body>

4、 案例:购物车案例模块-删除商品模块

1.核心思路:把商品remove() 删除元素便可

2.有三个地方须要删除: 1. 商品后面的删除按钮 2. 删除选中的商品 3. 清理购物车

3.商品后面的删除按钮: 必定是删除当前的商品,因此从 $(this) 出发

4.删除选中的商品: 先判断小的复选框按钮是否选中状态,若是是选中,则删除对应的商品

5.清理购物车: 则是把全部的商品所有删掉

6.每次清除都须要从新计算总额和总数,因此要调用以前封装好的函数

 

 // (1). 商品后面的删除按钮 
   $(".p-action a").click(function () {
       $(this).parents(".cart-item").remove();
       getSum();
  });
   // (2).删除选中的商品
   $(".remove-batch").click(function () {
       $(".j-checkbox:checked").parents(".cart-item").remove();
       getSum();
  });
   // (3).删除所有商品
   $(".clear-all").click(function () {
       $(".cart-item").remove();
       getSum();
  })

 

5、 案例:购物车案例模块-选中商品添加背景

1.核心思路:选中的商品添加背景,不选中移除背景便可

2.全选按钮点击:若是全选是选中的,则全部的商品添加背景,不然移除背景

3.小的复选框点击: 若是是选中状态,则当前商品添加背景,不然移除背景

4.这个背景,能够经过类名修改,添加类和删除类

 $(".checkall").change(function () {
       // console.log($(this).prop("checked"));
       $(".j-checkbox,.checkall").prop("checked", $(this).prop('checked'));
       // 若是全选框被选中,则给全部商品添加背景类名 .check-cart-item
       if ($(this).prop("checked")) {
           $(".cart-item").addClass("check-cart-item");
      } else {
           // 不然移除类名
           $(".cart-item").removeClass("check-cart-item");
      };
  });
   $(".j-checkbox").change(function () {
       // 每次改变小复选框状态都要判断小复选框是否全被选中
       // 若是小复选框选中的个数等于全部小复选框个数,则选中全选按钮 不然不选中
       // .j-checkbox:checked 选中的复选框
       if ($(".j-checkbox:checked").length === $(".j-checkbox").length) {
           $(".checkall").prop("checked", true);
      } else {
           $(".checkall").prop("checked", false);
      };
       // 若是小复选框被选中,则给当前商品添加背景类名 .check-cart-item
       if ($(this).prop("checked")) {
           $(this).parents(".cart-item").addClass("check-cart-item");
      } else {
           // 不然移除类名
           $(this).parents(".cart-item").removeClass("check-cart-item");

      };
  });
相关文章
相关标签/搜索