JavaScript---网络编程(7)-Dom模型(节点间的层次关系,节点的增、删、改)

简介: 利用节点间的层次关系获取节点: 上一节讲了3中获取的方式: * ※※一、绝对获取,获取元素的3种方式:—Element * 1、getElementById(): 通过标签中的id属性值获来取该标签对象 * 2、getElement...

利用节点间的层次关系获取节点:
上一节讲了3中获取的方式:
* ※※一、绝对获取,获取元素的3种方式:—Element
* 1、getElementById(): 通过标签中的id属性值获来取该标签对象
* 2、getElementsByName(): 通过标签中的name属性值来获取该标签对象集合
* 3、getElementsByTagName(): 通过标签名来获取该标签对象集合

现在来看看相对获取的方式:
※※二、相对获取(利用节点之间的层次关系),获取节点:—Node
1、父节点:parentNode–属性
2、子节点:childNodes–集合
3、上一个兄弟节点:previousSibling–属性
4、下一个兄弟节点:nextSibling–属性
5、使用以上属性时,要小心空白符节点(#Text)的存在。对于表格,还要注意有一个隐含的父节点。
*/

演示代码:

<html>
<head>
<title>Dom模型演示3---利用节点间的层次关系获取节点</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<script type="text/javascript">
    /*
     * ※※一、绝对获取,获取元素的3种方式:---Element
     * 1、getElementById(): 通过标签中的id属性值获来取该标签对象
     * 2、getElementsByName(): 通过标签中的name属性值来获取该标签对象集合
     * 3、getElementsByTagName(): 通过标签名来获取该标签对象集合

       ※※二、相对获取(利用节点之间的层次关系),获取节点:---Node
       1、父节点:parentNode--属性
       2、子节点:childNodes--集合
       3、上一个兄弟节点:previousSibling--属性
       4、下一个兄弟节点:nextSibling--属性
       5、使用以上属性时,要小心空白符节点(#Text)的存在。对于表格,还要注意<tr>有一个隐含的父节点<tbody>。
     */

    //通过节点间的层次关系来获取节点
    function getNodeByLevel() {
        var tabNode = document.getElementById("table1");
        //获取父节点

        var node = tabNode.parentNode;
        //alert(node.nodeName);//BODY,如果是IE6则是:TBODY
        //alert( tabNode.parentNode.parentNode.nodeName);//HTML

        //获取子节点
        /*
           使用childNodes时,需注意几点:
           1,<table>标签下还隐藏一个<tbody>标签,<tbody>下面才是<tr>
           2,空白符(空格或换行符)是被看成是一个文本节点的。例如,如果<table>和<tr>之间有换行或空格,则<table>的第一个孩子节点nodeName是:#text
           3, 上面的<tbody>和#text节点是兄弟关系
         */
        //需求:显示出表格中的所有姓名
        var children = tabNode.childNodes;
        //alert(children[0].nodeName);//#text
        //alert(children[1].nodeName);//<tbody>
        var trNodes = children[1].childNodes;
        alert(trNodes.length);
        var str="";

        for(var x=0;x<trNodes.length;x++){
            //用卫条件把<tr>与<td>之间的空白符过滤掉
            if(trNodes[x].nodeType==3){
                continue;
            }

            //注意,trNodes[x].childNodes[0]是空白符即#text节点,trNodes[x].childNodes[1]才是<td>节点
            //str=str+trNodes[x].childNodes[1].innerText+" ";
            //上面是偷懒写法,如果想写得兼容性好些,应该还用for循环遍历strNodes[x]的所有孩子节点且过滤掉#text节点,获取第一个非空白子节点的innerText


            for(var i=0;i<trNodes[x].childNodes.length;i++){
                if(trNodes[x].childNodes[i].nodeType==3){
                    continue;
                }
                str=str+trNodes[x].childNodes[i].innerText+" ";
                break;
            }

        }
        alert(str);

        //获取兄弟节点

        //上一个
        var node  = tabNode.previousSibling;
        alert(node.nodeName);//#text
        node = node.previousSibling;
        alert(node.nodeName);//BR

        //下一个
        var node = tabNode.nextSibling;
        alert(node.nodeName);//#text
        node = node.nextSibling;
        alert(node.nodeName);//HR
    }
</script>

</head>

<body>
    <div id="divId1">div区域1中的文字</div>
    <br/>
    <table id="table1">
        <tr>
            <td>Jack</td>
            <td>20</td>
        </tr>
        <tr>
            <td>张三</td>
            <td>23</td>
        </tr>
        <tr>
            <td>李四</td>
            <td>22</td>
        </tr>
        <tr>
            <td>罗斯</td>
            <td>22</td>
        </tr>
    </table>
    <hr />

    <input type="button" value="获取元素" onclick="getNodeByLevel()" />
</body>

</html>

部分演示结果:

节点的增、删、改操作–查有6种,在前面已经讲过

演示代码:

<html>
    <head>
        <title>Dom模型演示4---节点的增、删、改操作--查有6种,在前面已经讲过</title>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <style type="text/css">
            div{
                border: #0000ff solid 1px;
                width: 200px;
                padding: 30px;/*内补丁*/
                margin: 10px;/*外补丁*/
            }
            #div1{  background-color:#00ccff;   }/*设置或检索对象的背景颜色。*/
            #div2{  background-color:#ffccff;   }
            #div3{  background-color:#ffff00;   }
            #div4{  background-color:#00cc00;   }
        </style>
    </head>

    <body>
        <div id="div1"> </div>
        <div id="div2"> div区域2中的文字 </div>
        <div id="div3"> div区域3中的文字 </div>
        <div id="div4"> div区域4中的文字 </div>

        <hr/>

        <input type="button" value="添加一个文本节点" onclick="creataAndadd1()" >
        <input type="button" value="添加一个按钮节点" onclick="creataAndadd2()" >
        <input type="button" value="第三种添加方式" onclick="creataAndadd3()" >
        <br/>
        <input type="button" value="删除节点" onclick="delNode()" />
        <br/>
        <input type="button" value="移动替换节点" onclick="updateNode1()" />
        <input type="button" value="克隆替换节点" onclick="updateNode2()" />


        <script type="text/javascript">
            //添加一个文本节点
            function creataAndadd1(){
                //createTextNode 从指定值中创建文本字符串。 
                //创建一个文本节点
                var oTextNode = document.createTextNode("新添加的文本内容");
                //获取div1节点
                var oDivNode1 = document.getElementById("div1");
                //让div1节点把oTextNode节点添加为孩子
                oDivNode1.appendChild(oTextNode);
                //appendChild 给对象追加一个子元素。 
            }

            //添加一个按钮节点---基于对象,dom
            function creataAndadd2(){
                //创建一个按钮节点
                var oBtnNode = document.createElement("input");
                //createElement 为指定标签创建一个元素的实例。 

                oBtnNode.type="button";
                oBtnNode.value="一个按钮";

                //获取div1节点
                var oDivNode1 = document.getElementById("div1");
                //让div1节点把oBtnNode节点添加为孩子
                oDivNode1.appendChild(oBtnNode);
            }

            //第3种添加节点的方式---html的方式
            function creataAndadd3(){
                //获取div1节点
                var oDivNode1 = document.getElementById("div1");

                //innerHTML 设置或获取位于对象起始和结束标签内的 HTML。 
                //添加文本节点
                oDivNode1.innerHTML = "湖南城院";//只赋一个
                //oDivNode1.innerHTML +="湖南城院";//追加

                //继续添加按钮
                //oDivNode1.innerHTML = "<input type='button' value='按钮a'/> ";
                oDivNode1.innerHTML += "<input type='button' value='按钮a'/> ";
                //继续添加链接
                oDivNode1.innerHTML += "<a href='http://www.baidu.com'/>百度一下</a>";
            }

            //删除节点
            function delNode(){
                //获取div2节点
                var oDivNode2 = document.getElementById("div2");
                //oDivNode2.removeNode();//只删当前节点-removeNode 从文档层次中删除对象。
                //360-8.1浏览器中无效-IE支持
                //oDivNode2.removeNode(true);//删当前节点及子节点--子树-
                //360-8.1浏览器中无效-IE支持
                //※removeNode()方法不建议使用,因为这种删除不彻底!---建议使用父节点来删除
                //因为-自己删除自己,怎么可能删除干净嘛

                oDivNode2.parentNode.removeChild(oDivNode2);//都支持
                //removeChild 从元素上删除子结点。 
            }

            //修改节点1---移动替换
            function updateNode1(){
                var oDivNode1 = document.getElementById("div1");

                var oDivNode3 = document.getElementById("div3");
                //oDivNode1.replaceNode(oDivNode3);//自己替换,
                //不建议-360-8.1浏览器中无效-IE支持
                //replaceNode 用其它元素替换对象。 

                oDivNode1.parentNode.replaceChild(oDivNode3,oDivNode1);
                //replaceChild 用新的子元素替换已有的子元素。 
            }

            //修改节点2---克隆替换
            function updateNode2(){
                var oDivNode1 = document.getElementById("div1");
                var oDivNode3 = document.getElementById("div3");

                //var oDivNode3Clone = oDivNode3.cloneNode();//不包含子节点的克隆
                //cloneNode 从文档层次中复制对对象的引用。 
                var oDivNode3Clone = oDivNode3.cloneNode(true);//包含子节点的克隆
                oDivNode1.parentNode.replaceChild(oDivNode3Clone, oDivNode1);               
            }



        </script>

    </body>

</html>

演示结果:
一开始:

点第一个按钮:

再点第二个按钮:

再点第三个按钮:

再点第四个按钮:

点第五个按钮:

点第六个按钮;

目录
相关文章
|
18天前
|
消息中间件 存储 Serverless
函数计算产品使用问题之怎么访问网络附加存储(NAS)存储模型文件
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
18天前
|
Kubernetes 负载均衡 网络安全
Kubernetes 网络模型与实践
【8月更文第29天】Kubernetes(K8s)是当今容器编排领域的佼佼者,它提供了一种高效的方式来管理容器化应用的部署、扩展和运行。Kubernetes 的网络模型是其成功的关键因素之一,它支持服务发现、负载均衡和集群内外通信等功能。本文将深入探讨 Kubernetes 的网络模型,并通过实际代码示例来展示服务发现和服务网格的基本概念及其实现。
35 1
|
13天前
|
网络协议 数据安全/隐私保护 网络架构
计算机网络模型
【9月更文挑战第2天】
40 24
|
4天前
|
JavaScript 前端开发 API
探索Node.js中的异步编程模型
【9月更文挑战第11天】在JavaScript的运行环境中,Node.js因其高效的异步处理能力而备受青睐。本文将深入浅出地介绍Node.js如何处理异步操作,包括回调函数、Promises和async/await等概念,并探讨它们对后端开发的意义。
11 4
|
6天前
|
机器学习/深度学习 人工智能 自然语言处理
机器学习模型之深度神经网络的特点
深度神经网络(Deep Neural Networks, DNNs)是一类机器学习模型,通过多个层级(层)的神经元来模拟人脑的工作方式,从而实现复杂的数据处理和模式识别任务。
14 1
|
11天前
|
算法
基于GA遗传优化的离散交通网络双层规划模型设计matlab仿真
该程序基于GA遗传优化设计了离散交通网络的双层规划模型,以路段收费情况的优化为核心,并通过一氧化碳排放量评估环境影响。在MATLAB2022a版本中进行了验证,显示了系统总出行时间和区域排放最小化的过程。上层模型采用多目标优化策略,下层则确保总阻抗最小,实现整体最优解。
|
15天前
|
分布式计算 负载均衡 监控
p2p网络架构模型
P2P(Peer-to-Peer)模式是一种网络架构模型,在这种模型中,每个节点(peer)既是服务的提供者也是服务的消费者。这意味着每个参与的节点都可以直接与其他节点通信,并且可以相互提供资源和服务,例如文件共享、流媒体传输等。
19 6
|
12天前
|
网络协议 安全 网络安全
C语言 网络编程(四)常见网络模型
这段内容介绍了目前被广泛接受的三种网络模型:OSI七层模型、TCP五层模型以及TCP/IP四层模型,并简述了多个网络协议的功能与特性,包括HTTP、HTTPS、FTP、DNS、SMTP、TCP、UDP、IP、ICMP、ARP、RARP及SSH协议等,同时提到了ssh的免费开源实现openssh及其在Linux系统中的应用。
|
15天前
|
JavaScript 前端开发
JavaScript 与 DOM 交互
【9月更文挑战第01天】
16 2
|
15天前
|
机器学习/深度学习 存储 前端开发
实战揭秘:如何借助TensorFlow.js的强大力量,轻松将高效能的机器学习模型无缝集成到Web浏览器中,从而打造智能化的前端应用并优化用户体验
【8月更文挑战第31天】将机器学习模型集成到Web应用中,可让用户在浏览器内体验智能化功能。TensorFlow.js作为在客户端浏览器中运行的库,提供了强大支持。本文通过问答形式详细介绍如何使用TensorFlow.js将机器学习模型带入Web浏览器,并通过具体示例代码展示最佳实践。首先,需在HTML文件中引入TensorFlow.js库;接着,可通过加载预训练模型如MobileNet实现图像分类;然后,编写代码处理图像识别并显示结果;此外,还介绍了如何训练自定义模型及优化模型性能的方法,包括模型量化、剪枝和压缩等。
25 1