JavaScript的一些补充2

1.DOM的一些节点获取
 <div id="grandpa">
        <ul id="parent">
            <li id="son" class="li1">1</li>
            <li>2</li>
            <li>3</li>
        </ul>
    </div>
 	var grand = document.getElementById('grandpa');
    var parent = document.getElementById('parent');
    var son = document.getElementById('son');
    console.log(parent.parentNode);//获取DOM节点的父节点
    console.log(parent.childNodes);//获取元素所有子节点,包括文本和空格
    console.log(parent.firstChild);//获取元素的第一个子节点,包括文本及空格
    console.log(parent.firstElementChild);//获取元素的第一个子节点,不包括文本及空格
    console.log(parent.lastElementChild);//获取元素的最后一个子节点,不包括文本及空格
    console.log(parent.children);//获取元素所有子节点,不包括文本和空格
    console.log(son.nextSibling);//获取元素同级的相邻的节点(下一个),包括文本及空格
    console.log(son.previousSibling);//获取元素同级的相邻的节点(前一个),包括文本及空格
    console.log(son.nextElementSibling);//获取元素同级的相邻的节点(下一个),包括文本及空格
    console.log(son.previousElementSibling);//获取元素同级的相邻的节点(前一个),包括文本及空格
    console.log(son.attributes);//获取当前节点所有属性的集合

打印出的结果如下(图片中的结果与上面代码一一对应)
在这里插入图片描述
在这里插入图片描述

DOM节点的增删改查
  1. DOM节点的增加(appendChild和insertBefore)

例:

<ul id="ul1">
    <li>1</li>
    <li>2</li>
    <li>3</li>
</ul>

要想在ul中增加一个子节点li,先找到这个ul节点

var ul = document.getElementById('ul1')

然后创建一个li标签元素

var li = document.createElement('li');
li.innerText = 'hello world'

最后将这个li标签添加到ul中

appendChild
ul.appendChild(li)

运行后结果如下
在这里插入图片描述

appendChild是加在子元素的最后
insertBefore(插在指定的位置,有两个参数。第一个参数是要插入的节点,第二个参数是被插入的子节点)
 ul.insertBefore(li,ul.firstElementChild);//将li插在ul的第一个标签元素节点前

运行结果如下
在这里插入图片描述

  1. DOM节点的删除
    例:要将上面ul中最后一个子节点删除,代码如下
var li1 = document.getElementsByTagName('li');//获取所有li标签
ul.removeChild(li1[2]);

运行结果如下
在这里插入图片描述

  1. DOM节点的替换

例:将上面的ul中的第二个li节点换成新增的li节点,代码如下

ul.replaceChild(li,li1[2]);

结果如下
在这里插入图片描述

  1. DOM节点的复制
    例:将上面ul中的第一个节点复制一次并添加到ul中,代码如下
    var li2 = li1[0].cloneNode(true)//括号里的参数为布尔类型。true代表将这个节点下的所有内容全部复制,包括子代;false代表只复制这个标签;默认为false
    ul.appendChild(li2)

结果如下
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值