jQuery遍历与删除添加节点

news/2024/7/11 1:29:16 标签: jquery, 前端, javascript

个人名片:
😊作者简介:一名大二在校生
🤡 个人主页:坠入暮云间x
🐼
座右铭:懒惰受到的惩罚不仅仅是自己的失败,还有别人的成功。
🎅**学习目标: 坚持每一次的学习打卡

文章目录

    • 祖先元素
    • each()方法
    • 一、添加节点元素addNode
    • 二、删除节点
      • remove() 方法
    • empty() 方法
    • 复制节点与替换节点

jQuery遍历

遍历:jQuery 遍历,意为"移动",用于根据其相对于其他元素的关系来"查找"(或选取)HTML 元素。以某项选择开始,并沿着这个选择移动,直到抵达您期望的元素为止。

jQuery遍历
遍历:jQuery 遍历,意为"移动",用于根据其相对于其他元素的关系来"查找"(或选取)HTML 元素。以某项选择开始,并沿着这个选择移动,直到抵达您期望的元素为止。

在这里插入图片描述

  1. <div> 元素是 <ul> 的父元素,同时是其中所有内容的祖先。
  2. <ul> 元素是 <li> 元素的父元素,同时是 <div> 的子元素
  3. 左边的 <li> 元素是 <span> 的父元素,<ul> 的子元素,同时是 <div> 的后代。
  4. <span> 元素是 <li> 的子元素,同时是 <ul><div> 的后代。
  5. 两个 <li> 元素是同胞(拥有相同的父元素)。
  6. 右边的 <li> 元素是 <b> 的父元素,<ul> 的子元素,同时是 <div> 的后代。
  7. <b> 元素是右边的 <li> 的子元素,同时是 <ul><div> 的后代。

祖先元素

1**.parent()**方法直接返回被选元素的直接父元素

javascript">$(document).ready(function(){
  $("span").parent();
});

2.parents() 方法

parents() 方法返回被选元素的所有祖先元素,它一路向上直到文档的根元素 ()。

3.parentsUntil() 方法

parentsUntil() 方法返回介于两个给定元素之间的所有祖先元素。

代码示例:

javascript"><!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../jQuery文件/jquery-1.12.4.js"></script>
</head>

<body id="body1">
    <div id="div1">
        <ul id="ul1">
            <li id="li1">
                <span id="demo">hello</span>
            </li>
        </ul>
    </div>
</body>
<script>
    //parent()  获取父元素
    //parents()  获取所有祖先元素
    //parentsUntil(e)  获取e之后的所有祖先元素

    //1.获取hello的父元素的id
    //console.log($("#demo").parent().attr("id"));

    //2.获取hello的所有祖先元素的id
    // $("#demo").parents().each(function(){
    //     console.log($(this).attr("id"));
    // })

    //3.获取hello所有的div祖先的id
    // $("#demo").parents("div").each(function(){
    //     console.log($(this).attr("id"));
    // })
    //4.获取hello的祖先,且祖先在body之后
    $("#demo").parentsUntil("body").each(function(){
        console.log($(this).attr("id"));
    })
</script>

</html>

each()方法

each(): 方法为每个匹配元素规定要运行的函数。
语法$(selector).each(function*(index,element)*)

在这里插入图片描述

代码实例

javascript"><!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../jQuery文件/jquery-1.12.4.js"></script>
</head>

<body>

    <ul>
        <li>咖啡</li>
        <li>牛奶</li>
        <li>果汁</li>
        <li>红茶</li>
    </ul>

</body>
<script>
    //1.将ul下的所有li的文本变为“你好”
    //通过jQuery内部机制【隐式迭代】实现的
  //  $("ul li").text("你好");

    //2.循环输出所有的饮料
    //index:索引值 element:当前元素(一般用this即可)
    //这两个参数都是可以省略的
        // $("ul li").each(function(index,element){
        //     console.log(index+"_____"+element.innerHTML);
        // })
    //3.当索引为偶数时,将li的文本变为红色
    $("ul li").each(function(index){
           if(index % 2==0){
            $(this).css("color","red");
            $(this).css('opacity',(index+1)/10)
           }
        }) 
        $("ul li:even").css("color","red")
    //4.使用循环实现渐变 
    $("ul li").each(function(index){
        $(this).css("color","red");
        $(this).css('opacity',(index+1)/10)
        }) 
</script>

</html>

一、添加节点元素addNode

在这里插入图片描述

javascript"><!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../jQuery文件/jquery-1.12.4.js"></script>
</head>

<body>
    <ul>
        <li>咖啡</li>
        <li>牛奶</li>
        <li>果汁</li>
        <li>红茶</li>
    </ul>
    <button>末尾添加</button>
    <button>开头添加</button>
    <button>牛奶之前添加</button>
    <button>牛奶之后添加</button>
</body>
<script>
    //1.在ul子节点列表末尾添加奶茶1、奶茶2、奶茶3
    //第一步创建节点
    $("button:first").click(function(){
        //方式一:使用$()方法创建节点
        var li1 = $("<li></li>").text("奶茶1");
        //方式2:使用html标签创建节点
        var li2="<li>奶茶2</li>";
        //方法3:使用dom方法创建节点
        var li3=document.createElement("li");
        li3.innerHTML="奶茶3"
        //插入节点
        //方法1:使用append()
    //    $("ul").append(li1,li2,li3)
        //方法2:使用appendTo() 一次只能添加一个节点
        $(li1).appendTo("ul")
        $(li2).appendTo("ul")
        $(li3).appendTo("ul")
    })

    //2.在ul子节点列表开头添加冰淇淋
        $("button:contains('开头添加')").on("click",function() {
            var li=$("<li></li>").text("冰淇淋").css("color","red");
            $("ul").prepend(li);
            $(li).prependTo("ul")
        })

    //3.在“牛奶”之前加巧克力牛奶
        $("button:eq(2)").on("click",function(){
            //var li="<li style='color:red'>巧克力牛奶</li>";
            var li=$("<li></li>").text("巧克力牛奶").css("color","red")
            $("ul li:eq(1)").before(li)
        })

    //4.在“牛奶”之后加拿铁
    $("button:eq(3)").on("click",function(){
           var li=document.createElement("li");
           li.style.color="red"
           li.innerText="拿铁";
           $("ul li:eq(1)").after(li)
        })
</script>

</html>

二、删除节点

remove() 方法

remove() - 删除被选元素(及其子元素)

javascript">$("#div1").remove();

empty() 方法

empty() 方法删除被选元素的子元素。
语法:

javascript">$("#div1").empty();

代码示例

javascript"><!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../jQuery文件/jquery-1.12.4.js"></script>
</head>

<body>
    <ul>
        <li>咖啡</li>
        <li>牛奶</li>
        <li>果汁</li>
        <li>红茶</li>
    </ul>
    <ul>
        <li>波霸奶茶</li>
        <li>乌龙奶茶</li>
        <li>草莓奶茶</li>
    </ul>
    <button>删咖啡</button>
    <button>删牛奶</button>
    <button>删牛奶下面的</button>
    <button>删所有奶茶</button>
</body>
<script>
    //ele.remove(); 删除ele节点
        $("button:first").click(function(){
            $("ul:first li:first").remove();
        })  
        $("button:eq(1)").click(function(){
            $("ul:first li").remove(":eq(1)");
        })
        $("button:eq(2)").click(function(){
            $("ul:first li:gt(1)").remove();
            // $("ul:first li").each(function(index){
            //     if(index>1){
            //         $(this).remove();
            //     }
           // })
        })
        $("button:eq(3)").click(function(){
            $("ul:eq(1)").empty()
        })
    //ele.empty(); 删除ele节点下的所有子节点,注意,ele本身还在
    
</script>

</html>

复制节点与替换节点

javascript"> 
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../jQuery文件/jquery-1.12.4.js"></script>
</head>

<body>
    <div id="div1">
        <p style="color:red;font-size: 30px;">大家好,我是p
            <span style="color:orange">我是p里面的span1</span>
            <span style="color:green">我是p里面的span2</span>
        </p>
    </div>
    <button id="copyNode">复制节点</button>
    <button id="replaceNode">替换节点</button>
</body>
<script>
    $("#copyNode").click(function(){
        //第一步复制节点clone()
        var ele=$("#div1 p:first span:eq(1)").clone();
        //第二步插入
        $("#div1 p:first").append(ele)
    })

    //replaceWith()
    //replaceAll()
    $("#replaceNode").click(function(){
        //写法1:
       // $("<button>注册</button>").replaceAll("#div1 p:first span:eq(1)");
        $("#div1 p:first span:eq(1)").replaceWith("<button>注册</button>")
    })
</script>

</html>

http://www.niftyadmin.cn/n/5257487.html

相关文章

Spring(Spring/Springboot 的创建) 基础

一. Spring 1.1 Spring是什么&#xff1f; Spring 指的是 Spring Frameword(Spring 框架),它是一个开源框架。 Spring 是包含了众多工具方法的IoC容器。 1.2 什么是容器&#xff1f; 容器时用来容纳某种物品的装置。 我们之前接触到的容器&#xff1a; • List/Map ->…

STM32——超声波传感器

需求&#xff1a; 使用超声波测距&#xff0c;当手离传感器距离小于 5cm 时&#xff0c; LED1 点亮&#xff0c;否则保持不亮状态 接线&#xff1a; 定时器配置&#xff1a; 使用 TIM2 &#xff0c;只用作计数功能&#xff0c;不用作定时。 将 PSC 配置为 71 &#xff0c;…

产品经理学习总结(4)—— 产品伪需求与弱需求如何一眼识破?

前言 在作为产品经理的日常工作中&#xff0c;经常会面临一个问题&#xff1a;如何区分真实需求、伪需求与弱需求&#xff1f;有一次&#xff0c;我收到了一封用户的反馈邮件&#xff0c;描述了一个他认为极为实用的功能点。我心动了&#xff0c;觉得这个功能可能会是下一个爆…

Leetcode—2961.双模幂运算【中等】

2023每日刷题&#xff08;五十六&#xff09; Leetcode—2961.双模幂运算 实现代码 class Solution { public:int func(int a, int b) {int ans 1;for(int i 0; i < b; i) {ans * a;ans % 10;}return ans;}int func2(int a, int b, int m) {int ans 1;for(int i 0; i …

鸿蒙开发 - ohpm安装第三方库

前端开发难免使用第三方库&#xff0c;鸿蒙亦是如此&#xff0c;在使用 DevEco Studio 开发工具时&#xff0c;如何引入第三方库呢&#xff1f;操作步骤如下&#xff0c;假设你使用的是MacOS&#xff0c;假设你已经创建了了一个项目&#xff1a; 一、配置 HTTP Proxy 在打开了…

C 语言关于位运行符

C 语言提供了一系列位运算符&#xff0c;用于对二进制位进行操作。这些运算符在处理位级数据、进行性能优化以及实现特定的算法时非常有用。 按位与运算符&#xff08;&&#xff09;&#xff1a;两个相应的二进制位都为 1 时&#xff0c;结果才为 1。例如&#xff0c;a &a…

大语言模型--引言

引言 大语言模型 引言语言模型自回归语言模型(Autoregressive language models)小结 语言模型 语言模型&#xff08;LM&#xff09;的经典定义是一种对令牌序列&#xff08;token&#xff09;的概率分布。假设我们有一个令牌集的令牌表 V V V。 语言模型每个为令牌序列 x 1 , …

《天天爱科学》期刊国家级知网投稿

《天天爱科学》国家级期刊知网收录&#xff0c;投稿方向&#xff1a;幼儿教育、基础教育文章&#xff0c;不收案例分析、教学设计、图表讲解、例题分析。 刊名&#xff1a;天天爱科学 主管单位&#xff1a;中国出版传媒股份有限公司 主办单位&#xff1a;人民文学出版社有限…