【Web APIS】05-节点操作

节点简介

  1. 为什么要学节点操作?

通过节点对元素增删改查更简单

在这里插入图片描述
3. 节点概述

网页中的内容都是节点:标签,属性,文本,注释,包括换行
一般地,节点至少拥有三个属性:节点类型(noType),节点名称和节点值:

  1. 元素节点nodeType 为1
  2. 属性节点noType 为23
  3. 文本节点 noType 为3
  • 实际开发中,节点操作的主要是元素节点

在这里插入图片描述

节点操作

节点层级

在这里插入图片描述

节点操作-父节点

node.parentNode
获取最近的父级节点:node.parentNode;找不到则返回null

<body>
    <div class="box">
        <ul>
            <li>li1</li>
            <li>li2</li>
            <li>li3</li>
        </ul>
        <ol>
            <li></li>
            <li></li>
            <li></li>
        </ol>
    </div>
    <script>
    // 1.获取父节点
        // 如淘宝的关闭二维码菜单,既需要获取子元素,又需要获取父元素,点击子元素的x再关闭整个父元素(繁琐)
        var ul = document.querySelector('ul');
        // var box = document.querySelector('div');
       console.log( ul.parentNode);//获取最近的父级节点:node.parentNode;找不到则返回null

    </script>
</body>

节点操作-子节点

获取子节点两种方法

  1. childNodes获取所有的子节点(包括文本,元素,属性节点),只获取元素节点需要封装函数处理,所以不推荐
  2. children获取所有的子元素节点,目前实际开发常用的;用法:parentNode.children
<body>
    <div class="box">
        <ul>
            <li>li1</li>
            <li>li2</li>
            <li>li3</li>
        </ul>
        <ol>
            <li></li>
            <li></li>
            <li></li>
        </ol>
    </div>
    <script>
        var ul = document.querySelector('ul');
    // 获取子节点
        // (1)childNodes获取所有的子节点(包括文本,元素,属性节点),只获取元素节点需要处理,不考虑
        // (2)children获取所有的子元素节点,目前实际开发常用的;用法:parentNode.children
       console.log( ul.children);//HTMLCollection(3) [li, li, li]

    </script>
</body>

节点操作-第一个子元素节点和最后一个子元素

获取第一个子元素节点和最后一个子元素节点三种方法

  1. firstChild 第一个子节点,无论是文本节点还是元素节点(通常操作元素节点,不考虑此方法)
  2. firstElementChild和lastElementChild返回第一个子元素节点和最后一个子元素节点;存在兼容性问题,但2020.6.18已弃用ie,后续大概率常用
  3. 目前为止,实际开发中的写法(通过children[]):
    console.log( ul.children[0]);;//返回第一个元素节点
    console.log(ul.children[ul.children.length-1]);//返回最后一个元素节点
<body>
    <div class="box">
        <ul>
            <li>li1</li>
            <li>li2</li>
            <li>li3</li>
        </ul>
        <ol>
            <li></li>
            <li></li>
            <li></li>
        </ol>
    </div>
    <script>
       var ul = document.querySelector('ul');
// 获取第一个子元素节点和最后一个子元素节点
        // (1)firstChild 第一个子节点,无论是文本节点还是元素节点(通常操作元素节点,不考虑此方法)
        // (2)firstElementChild和lastElementChild返回第一个子元素节点和最后一个子元素节点;存在兼容性问题,但2020.6.18已弃用ie,后续大概率常用
        // (3)目前为止,实际开发中的写法:
        console.log( ul.children[0]);;//返回第一个元素节点
        console.log(ul.children[ul.children.length-1]);//返回最后一个元素节点
    </script>
</body>

节点操作案例1:新浪下拉菜单

  • 通过节点操作实现下拉菜单,巩固节点操作知识

在这里插入图片描述

  • 案例代码:
<style>
        * {
            margin: 0;
            padding: 0;
        }
        li{
            list-style: none;
        }
        a{
            text-decoration: none;
        }
        .nav{
            background-color: #bfa;
            margin: 150px;
            text-align: center;
        }
        .nav>li{
            float: left;
            position: relative;
            width: 115px;
            height: 45px;
            line-height: 45px;
        }
        .nav li a {
            display: block;
            width: 100%;
            height: 100%;
            line-height: 45px;
            color: #333;
            font-size: 14px;
        }

        .nav ul{
            display: none;
            position: absolute;
            top: 45px;
            left: 0;
            width: 100%;
            border-left: 1px solid #FECC5B;
            border-right: 1px solid #FECC5B;
        }
        .nav ul li{
            border-bottom: 1px solid #FECC5B;
        }
      .nav li a:hover{
        background-color: #bfa;
      }
    </style>
</head>

<body>
    <ul class="nav">
        <li>
            <a href="#">微博</a>
            <ul>
                <li>私信</li>
                <li>评论</li>
                <li>@我</li>
            </ul>
        </li>
        <li>
            <a href="#">微博</a>
            <ul>
                <li>私信</li>
                <li>评论</li>
                <li>@我</li>
            </ul>
        </li>
        <li>
            <a href="#">微博</a>
            <ul>
                <li>私信</li>
                <li>评论</li>
                <li>@我</li>
            </ul>
        </li>
        <li>
            <a href="#">微博</a>
            <ul>
                <li>私信</li>
                <li>评论</li>
                <li>@我</li>
            </ul>
        </li>
    </ul>
    <script>
        // 获取元素
        var nav = document.querySelector('.nav');
        var lis = nav.children;//获取四个小li
        // 循环注册事件 
        for(var i = 0;i<lis.length; i++){
            // 鼠标移入时
            lis[i].onmouseover = function(){
                // this.children[this.children.length-1].style.display = 'block';//选取li中最后一个子元素节点ul
                // this.children[1].style.display = 'block';//第二个子节点li
                this.lastElementChild.style.display = 'block';//直接选择最后一个子节点
            }
            lis[i].onmouseout = function(){
                this.children[this.children.length-1].style.display = 'none';
            }

        }
    </script>
</body>

节点操作-兄弟节点

  1. nextSibbling下一个兄弟节点,包含文本节点等
    console.log( div.nextSibling);//#text
  2. 上一个兄弟节点,包含文本
    console.log(div.previousSibling);//#text;
    常用3,4种,因为是兄弟元素节点,且被弃用ie的不兼容现在无需考虑
  3. nextElementSibling下一个兄弟元素节点
    console.log( div.nextElementSibling);
  4. 上一个兄弟元素节点,没有则返回null
    console.log(div.previousElementSibling);
<body>
    <div>我是div</div>
    <span>我是span</span>
    <script>
        var div =document.querySelector('div');
        // 1.nextSibbling下一个兄弟节点,包含文本节点等
        console.log(  div.nextSibling);//#text 
        console.log(div.previousSibling);//#text;上一个兄弟节点,包含文本
        // 2.nextElementSibling下一个兄弟元素节点
      console.log(  div.nextElementSibling);
      console.log(div.previousElementSibling);//上一个兄弟元素节点,没有则返回null
    </script>
</body>

节点操作-创建和添加节点

  1. 创建(元素)节点
    在这里插入图片描述
  2. 添加节点
    在这里插入图片描述
  3. 使用示例:
<body>
    <ul>
        <li>123</li>
    </ul>
    <script>
    // 给页面添加一个新的元素:1.创建元素;2.添加元素
        // 1.创建元素节点
        var li = document.createElement('li');
        // 2.添加节点 node.appendChild(child);node是父级,child是子级
            // -后面追加元素,类似于数组中的push
        var ul = document.querySelector('ul');
        ul.appendChild(li);
        // 3.node.insertBefore(child,指定元素);在指定元素节点前添加节点
        var lili = document.createElement('li');
        ul.insertBefore(lili,ul.children[0]);//在ul的第一个子节点(内容为123)的前面添加一个li
    </script>
</body>

节点操作案例2:简单版发布留言

  • 进行创建和添加节点练习的案例:每次输入内容点击发布,会新增一条留言

在这里插入图片描述

  • 案例代码:
   <style>
        li{
            background-color: pink;
            width: 600px;
            margin: 10px 0;
            color: black;
        }
    </style>
</head>
<body>
    <textarea name="" id="message" cols="30" rows="10"></textarea><button>发布</button>
    <ul>
        <li>123</li>
    </ul>
    
    <script>
        // 获取元素
        var btn = document.querySelector('button');
        var ul = document.querySelector('ul');
        var text = document.querySelector('textarea');
        // 绑定点击事件
        btn.onclick = function(){
            if(text.value == ''){
                alert('你输入的内容为空');
                return false;
            }else{
                var li = document.createElement('li');
                ul.appendChild(li);
                // li.innerHTML = text.value;
                li.innerHTML = document.getElementById('message').value;//取出textarea的值赋给li的innerhtml
                document.getElementById('message').value = '';

            }
            
        }
      
    </script>
</body>

节点操作-删除节点

在这里插入图片描述
用法示例:点击一次按钮删除一个在这里插入图片描述
代码示例:

<body>
    <button>删除一个</button>
    <ul>
        <li>苹果</li>
        <li></li>
        <li>香蕉</li>
    </ul>
    <script>
    //删除节点 node.removeChild();node父节点
    // 获取元素
    var btn = document.querySelector('button');
    var ul = document.querySelector('ul');
    // 绑定事件 处理程序
    btn.onclick = function(){
        if(ul.children.length == 0){
            // this.disabled = true;若想设置删完禁用点击
            //设置提示删除完毕
            alert('你已经全部删除了,亲');
            return false;
        }else{
            ul.removeChild(ul.children[0]); 
        }
    }
    </script>
    
</body>

节点操作案例3:删除留言

  • 在案例2的基础上新增删除功能

在这里插入图片描述

  • 案例代码:
 <style>
        li {
            background-color: pink;
            width: 600px;
            margin: 10px 0;
            color: black;

        }

        li a {
            float: right;
        }
    </style>
</head>

<body>
    <textarea name="" id="message" cols="30" rows="10"></textarea><button>发布</button>
    <ul>

    </ul>


    <script>
        // 获取元素
        var btn = document.querySelector('button');
        var ul = document.querySelector('ul');
        var text = document.querySelector('textarea');
        // 绑定点击事件
        btn.onclick = function () {
            if (text.value == '') {
                alert('你输入的内容为空');
                return false;
            } else {
                var li = document.createElement('li');
                ul.appendChild(li);
                // li.innerHTML = text.value;
                li.innerHTML = document.getElementById('message').value + "<a href=javascript:;>删除</a>";//取出textarea的值赋给li的innerhtml
                document.getElementById('message').value = '';

                // 点击删除,山吹当前a链接父节点
                var as = document.querySelectorAll('a');
                for (var i = 0; i < as.length; i++) {
                    as[i].onclick = function () {
                        ul.removeChild(this.parentNode);
                    }
                }


            }

        }


    </script>

</body>

节点操作-复制节点

在这里插入图片描述

动态生成表格案例

  • 案例需求:表格根据数据的变化而变化
  • 实现思路:由于未采用数据库,通过定义数组,在数组中以对象的形式存入定义好的数据来模拟数据;然后通过上述知识实现此案例

在这里插入图片描述

  • 案例代码:
   <style>
        table {
            border-collapse: collapse;
            margin-top: 200px;
            margin-left: 500px;
        }
        table th{
            border: 1px solid black;
            width: 80px;
            height: 40px;
            text-align: center;
            background-color: cornsilk;
        }

        table td{
           
            border: 1px solid black;
            width: 80px;
            height: 40px;
            text-align: center;

        }

    </style>
</head>
<body>
    <table>
        <thead>
            <tr>
                <th>姓名</th>
                <th>科目</th>
                <th>成绩</th>
                <th>操作</th>
         </tr>
        </thead>
        <tbody>
        </tbody>
    </table>
    <script>

        //加入数据
        var datas = [
            {
                name:'张三',
                subject:'JavaScript',
                score:'100'
            },
            {
                name:'李四',
                subject:'JavaScript',
                score:'95'
            },
            {
                name:'王五',
                subject:'JavaScript',
                score:'98'
            },
            {
                name:'赵六',
                subject:'JavaScript',
                score:'92'
            }
        ];
        //创建行,有几个人就创建几行
        var tbody =document.querySelector('tbody')
        for(var i = 0 ; i < datas.length ; i++){
            //创建行
            var tr = document.createElement('tr');
            tbody.appendChild(tr);
            //创建单元格
            for (var k in datas[i] ){
                var td = document.createElement("td");
                td.innerText = datas[i][k];
                tr.appendChild(td);
            }
            //创建删除单元格
            var td = document.createElement('td');
            td.innerHTML = '<a href="JavaScript:;">删除</a>';
            tr.appendChild(td);
        }
        var as = document.querySelectorAll('a');
        for (var i = 0 ; i <as.length ; i++){
            as[i].onclick = function(){
                //点击a 删除当前行
                tbody.removeChild(this.parentNode.parentNode);
            }
        }

        // for (var k in Obj){
        //      k 得到的是属性名
        //      dbj[k] 得到的是属性值
        // }
    </script>
</body>
</html>

三种动态创建元素的区别

  • 了解document.write()
  • innerHTML和createElement()效率对比

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: APIs IQ-FMEA软件使用手册是一个详细的说明文档,它向用户介绍了使用APIs IQ-FMEA软件的必要步骤和注意事项。 该手册包含了软件的安装、启动和配置过程的详细说明,同时详细介绍了软件的功能和操作界面。用户可以根据手册的指导,逐步了解软件的各项功能和操作方法,并能够快速地使用它来进行FMEA分析。 手册的主要内容包括:软件的基本界面和菜单栏介绍,FMEA分析的基本概念和步骤,创建FMEA项目的方法和注意事项,如何输入和管理FMEA数据,对FMEA数据进行分析和评估的方法,以及如何导出和分享FMEA分析结果等。 除此之外,手册还包括了一些常见问题的解答和故障排除方法,以便用户在使用软件时遇到问题时能够进行及时的解决和应对。 总之,APIs IQ-FMEA软件使用手册全面、系统地介绍了该软件的使用方法和注意事项,对于使用该软件进行FMEA分析的用户来说,具有非常重要的参考价值。 ### 回答2: APIs IQ-FMEA是一款风险分析软件,主要用于产品设计、生产和维护过程中的风险分析。软件使用手册主要介绍了APIs IQ-FMEA软件的安装、如何建立FMEA档案,如何填写FMEA,并对分析结果进行解释。 首先,用户需要正确安装APIs IQ-FMEA软件,并按照软件提供的流程和步骤建立FMEA档案。在建立FMEA档案之前,用户需要了解所分析的系统和产品的全貌,明确其特点、功能、原理和性能指标。FMEA档案建立好之后,用户需要按照FMEA表格的要求填写相应内容,包括零部件名称、功能要求、失效模式、失效后果、失效严重性等内容。针对各项分析指标,用户需要逐一填写,确保准确、完整。 在填写FMEA过程中,需要注意一些问题。例如,失效模式应尽可能地详尽和准确地描述,失效后果应根据实际情况分析,而非猜疑和臆测,失效严重性的分类与分值应根据相关标准和经验进行判定。此外,一定要对不确定的分析指标进行标识,确保再次分析和修正。 分析结束之后,用户可以根据得出的FMEA结果进行分析和解释。软件提供了多种图表和统计分析方法,可以帮助用户快速了解和评估分析结果。用户可以根据得到的结果进行相应的改进和优化,确保产品和系统的质量和可靠性。 总之,APIs IQ-FMEA是一款非常实用的风险分析软件,使用手册详细介绍了软件的使用流程和技巧,能够帮助用户更准确地进行风险分析和评估。在正式使用前,用户需要认真阅读和理解使用手册,并进行充分的培训和实践,以确保软件能够发挥最大的效益。 ### 回答3: APIs IQ-FMEA软件使用手册(中文)是一本非常重要的参考书籍,用于帮助用户了解如何使用该软件生成FMEA报告。该软件旨在帮助用户减少或消除产品或过程中可能出现的故障或缺陷,从而提高质量和可靠性,降低成本。 该软件使用手册涵盖了软件的全部功能。这包括创建FMEA的工作流程,FMEA的输出和分析,以及生成和管理FMEA报告的功能。在阅读完该手册后,用户将具备以下技能: 1. 使用软件创建FMEA:用户将学会如何使用该软件的各种功能来创建FMEA。这包括建立控制计划、识别可能失效模式、评估失效影响以及制定纠正措施等。 2. 分析FMEA的输出数据:用户将学会如何使用APIs IQ-FMEA软件的输出数据来评估失效模式、失效影响和措施效果。用户将了解如何使用该软件提供的分析工具来识别优先处理的故障模式、降低潜在风险并提高生产效率。 3. 生成和管理FMEA报告:用户将学会如何使用该软件生成FMEA报告并管理相关的文件。该手册提供了有关如何使用自定义模板和生成多种报告格式,包括Word、Excel、PDF等的详细指南,以及如何管理版本控制和FMEA报告的权限等。 总之,APIs IQ-FMEA软件使用手册(中文)是一本很有价值的参考书籍。它将帮助用户掌握该软件并创建高质量的FMEA报告,从而提高产品或过程的质量和可靠性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值