前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >jQuery 元素操作

jQuery 元素操作

作者头像
梨涡浅笑
发布2022-05-08 15:30:48
1.9K0
发布2022-05-08 15:30:48
举报
文章被收录于专栏:全栈自学笔记全栈自学笔记

1. jQuery 元素操作

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

1.1. 遍历元素

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

语法1

代码语言:javascript
复制
$("div").each(function (index, domEle) { xxx; }) 

1. each() 方法遍历匹配的每一个元素。主要用DOM处理。 each 每一个 2. 里面的回调函数有2个参数:  index 是每个元素的索引号;  demEle 是每个DOM元素对象,不是jquery对象 3. 所以要想使用jquery方法,需要给这个dom元素转换为jquery对象  $(domEle)

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

语法2

代码语言:javascript
复制
$.each(object,function (index, element) { xxx; })     

1. $.each()方法可用于遍历任何对象。主要用于数据处理,比如数组,对象 2. 里面的函数有2个参数:  index 是每个元素的索引号;  element  遍历内容

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

代码语言:javascript
复制
<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>

1.2. 案例:购物车案例模块-计算总计和总额

1.把所有文本框中的值相加就是总额数量,总计同理。2.文本框里面的值不同,如果想要相加需要用 each() 遍历,声明一个变量做计数器,累加即可。

代码语言:javascript
复制
 // 5. 计算总计和总额模块
    getSum();

    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) {
            money += parseFloat($(ele).text().substr(1));
        });
        $(".price-sum em").text("¥" + money.toFixed(2));
    }

1.3. 创建、添加、删除

​ jQuery方法操作元素的创建、添加、删除方法很多,则重点使用部分,如下:

语法总和

1. 动态的创建了一个 <li>

代码语言:javascript
复制
$(''<li></li>'');     

2.1. 内部添加

代码语言:javascript
复制
element.append(''内容'')   
element.prepend(''内容'')  

把内容放入匹配元素内部最后面,类似原生 appendChild。

2.2 外部添加

把内容放入匹配元素内部最前面。

代码语言:javascript
复制
element.after(''内容'')        //  把内容放入目标元素后面
element.before(''内容'')    //  把内容放入目标元素前面  

① 内部添加元素,生成之后,它们是父子关系。 ② 外部添加元素,生成之后,他们是兄弟关系。

3.删除元素

代码语言:javascript
复制
element.remove()   //  删除匹配的元素(本身) 
element.empty()    //  删除匹配的元素集合中所有的子节点
element.html('''')   //  清空匹配的元素内容

① remove 删除元素本身。 ② empt() 和  html('''') 作用等价,都可以删除元素里面的内容,只不过 html 还可以设置内容。

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

案例代码

代码语言:javascript
复制
<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>

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

1.核心思路:把商品remove() 删除元素即可 2.有三个地方需要删除: 1. 商品后面的删除按钮 2. 删除选中的商品 3. 清理购物车3.商品后面的删除按钮: 一定是删除当前的商品,所以从 $(this) 出发4.删除选中的商品: 先判断小的复选框按钮是否选中状态,如果是选中,则删除对应的商品5.清理购物车: 则是把所有的商品全部删掉

代码语言:javascript
复制
// 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();
    })
})

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

1.核心思路:选中的商品添加背景,不选中移除背景即可2.全选按钮点击:如果全选是选中的,则所有的商品添加背景,否则移除背景3.小的复选框点击: 如果是选中状态,则当前商品添加背景,否则移除背景4.这个背景,可以通过类名修改,添加类和删除类

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-10-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. jQuery 元素操作
    • 1.1. 遍历元素
      • 1.2. 案例:购物车案例模块-计算总计和总额
        • 1.3. 创建、添加、删除
          • 1.4 案例:购物车案例模块-删除商品模块
            • 1.5 案例:购物车案例模块-选中商品添加背景
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档