HTML元素的操作

获取HTML的值

获取文本内容

1.先获取元素的内容

2.使用innerText方法

js 复制代码
    let btn = document.getElementById("btn");
    //获取文本内容
    console.log(btn.innerText);

设置文本内容

js 复制代码
btn.innerText= "测试数据";
let box = document.getElementById("box");

获取div中的html代码 innerHTML方法

js 复制代码
console.log(box.innerHTML);

将html代码 覆盖到div中

js 复制代码
//将html代码 覆盖到div中
box.innerHTML = "<h2>测试数据</h2>";
let a = document.getElementsByTagName("a");

更新HTML元素

创建html元素 createElement()

js 复制代码
 let ul = document.createElement("ul");

 let li1 = document.createElement("li");

创建文本节点 createTextNode()

js 复制代码
let text1 = document.createTextNode("列表项1");

将文本节点 追加到 li 节点中的末尾 appendChild()

js 复制代码
 li1.appendChild(text1);
 ul.appendChild(li1);
let li2 = document.createElement("li");

改变HTML中的元素

js 复制代码
<body>
<ul id="ul">
    <li id="first">列表1</li>
    <li>列表2</li>
    <li>列表3</li>
    <li id="last">列表4</li>
</ul>
<script>
    let ul = document.getElementById("ul");
    let first = document.getElementById("first");
    let last = document.getElementById("last");
    // 通过父级删除子集
    // ul.removeChild(first);
    //删除当前元素
    // first.remove();
    //替换内容
    // let repLi = document.createElement("li");
    // repLi.innerText = '列表项4的替换内容';
    // ul.replaceChild(repLi,last);

    let instLi = document.createElement("li");
    instLi.innerText = '列表项1前插入的内容';
    ul.insertBefore(instLi,first);

</script>
</body>

获取元素的父级

HTML部分

html 复制代码
<div id="box">
    <ul id="ul">
        <li><a href="#">列表项目1</a></li>
        <li id="two"><a href="#">列表项目2</a></li>
        <li><a href="#">列表项目3</a></li>
        <li><a href="#">列表项目4</a></li>
    </ul>
</div>

JavaScript根据ID获取元素部分

js 复制代码
let box = document.getElementById("box");
let ul = document.getElementById("ul");
let two = document.getElementById("two");

获取元素的父级

parentBode:parentNode 属性返回元素或节点的父节点

parentELement:parentElement 属性返回指定元素的父元素。

parentElementparentNode 的区别在于,如果父节点不是元素节点,则 parentElement 返回 null

js 复制代码
console.log(ul.parentNode);
console.log(ul.parentElement);

获取子集元素 包含 换行

childNodes: childNodes 返回包含指定节点的子节点的集合,该集合为即时更新的集合

children: children 属性返回元素的子元素的集合,根据子元素在元素中出现的先后顺序进行排序。使用 HTML Collection对象的 length属性获取子元素的数量,然后使用序列号(index,起始值为0)访问每个子元素。

children 属性与 childNodes 属性的差别:

  • childNodes 属性返回所有的节点,包括文本节点、注释节点;
  • children 属性只返回元素节点;
js 复制代码
console.log(box.childNodes);
console.log(box.children);

获取子集的第一个元素 包含换行

firstChild:选择属于其父元素的首个子元素的每个

元素,并为其设置样式;

firstElementChild: firstElementChild 属性返回指定元素的第一个子元素

firstElementChild 属性与 firstChild, 属性的区别在于 firstChild 返回第一个子节点作为元素节点,包含文本节点或注释节点(取决于哪个是第一个),而firstElementChild 返回第一个子节点作为元素节点(忽略文本和注释节点)。该属性是只读的。

js 复制代码
console.log(ul.firstChild);
console.log(ul.firstElementChild);

获取子集的最后一个元素 包含换行

lastChild:lastChild 属性返回指定节点的最后一个子节点,以 Node 对象。

lastElementChild:lastElementChild 属性返回指定元素的最后一个子元素。

lastElementChild 属性与 lastChild 属性的区别在于 lastChild 返回最后一个子节点作为元素节点,包含文本节点或注释节点(取决于哪个是最后一个),而 lastElementChild 返回最后一个子节点作为元素节点(忽略文本和注释节点)。该属性是只读的。

js 复制代码
      console.log(ul.lastChild);
      console.log(ul.lastElementChild);

获取当前元素的前一个元素

previousSibling:previousSibling 属性返回同一树级别的上一个节点,以 Node 对象。如果没有 previousSibling 节点,则返回值是 null

previousElementSibling:previousElementSibling 属性返回指定元素的前一个兄弟元素(相同节点树层中的前一个元素节点)

previousSibling 属性与 previousElementSibling 属性的差别:

  • previousSibling 属性返回元素节点之前的兄弟节点(包括文本节点、注释节点);

  • previousElementSibling 属性只返回元素节点之前的兄弟元素节点(不包括文本节点、注释节点);

    复制代码
        console.log(two.previousSibling);
        console.log(two.previousElementSibling);

获取当前元素的下一个元素

nextSibling:nextSibling 属性返回同一树级别上的下一个节点。nextSibling 返回下一个同胞节点:元素节点、文本节点或注释节点。元素之间的空白也是文本节点。

nextElementSibling:nextElementSibling 属性返回指定元素之后的下一个兄弟元素(相同节点树层中的下一个元素节点)。

nextSibling 属性与 nextElementSibling 属性的差别:

  • nextSibling 属性返回元素节点之后的兄弟节点(包括文本节点、注释节点)
  • nextElementSibling 属性只返回元素节点之后的兄弟元素节点(不包括文本节点、注释节点);
js 复制代码
      console.log(two.nextSibling);
      console.log(two.nextElementSibling);
相关推荐
喝拿铁写前端1 分钟前
前端批量校验还能这么写?函数式校验器组合太香了!
前端·javascript·架构
巴巴_羊5 分钟前
6-16阿里前端面试记录
前端·面试·职场和发展
我是若尘7 分钟前
前端遇到接口批量异常导致 Toast 弹窗轰炸该如何处理?
前端
该用户已不存在30 分钟前
8个Docker的最佳替代方案,重塑你的开发工作流
前端·后端·docker
然我32 分钟前
面试官最爱的 “考试思维”:用闭包秒杀递归难题 🚀
前端·javascript·面试
明月与玄武40 分钟前
HTML知识全解析:从入门到精通的前端指南(上)
前端·html
teeeeeeemo1 小时前
CSS place-items: center; 详解与用法
前端·css·笔记
未来之窗软件服务1 小时前
html读取身份证【成都鱼住未来身份证】:CyberWinApp-SAAS 本地化及未来之窗行业应用跨平台架构
前端·html·身份证读取
木木jio1 小时前
🧹 前端日志查询组件的重构实践:从 1600 行巨型组件到模块化 hooks
前端·react.js