Skip to content
鼓励作者:欢迎打赏犒劳

11-DOM相关

获取元素

closest()方法可以沿着DOM树向上遍历,直到找到匹配的选择器的第一个祖先元素(包括它自己)。然后你可以从这个祖先元素中选择你想要的子元素。

js
// 从按钮开始,找到最近的.item容器
let itemContainer = document.getElementById('myId').closest('.item');
js
// 在.item容器内查找img元素
let imgElement = itemContainer.querySelector('.item-img img');

DOM插入子元素

使用 innerHTML

这是最简单的方法之一,但需要注意这会替换元素中的所有内容。

js
const element = document.getElementById('myElement');
element.innerHTML += '<div>这是一个新的片段</div>';

使用insertAdjacentHTML

这个方法允许你更灵活地插入 HTML 片段而不替换元素中已有的内容。

js
const element = document.getElementById('myElement');
element.insertAdjacentHTML('beforeend', '<div>这是一个新的片段</div>');

在 insertAdjacentHTML 方法中,第二个参数指定了如何插入新内容。可用的选项包括:

  • beforebegin: 在元素之前
  • afterbegin: 在元素内部的最开始
  • beforeend: 在元素内部的最后
  • afterend: 在元素之后
html
<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>DOM 示例</title>
</head>
<body>
    <div id="myElement">
        <p>原始内容</p >
    </div>
    <button id="addContent">添加内容</button>

    <script>
        document.getElementById('addContent').addEventListener('click', () => {
            // 使用 insertAdjacentHTML 添加内容
            const element = document.getElementById('myElement');
            element.insertAdjacentHTML('beforeend', '<div>这是一个新的片段</div>');
        });
    </script>
</body>
</html>

使用appendChild

如果你想创建元素并添加事件,也可以使用 appendChild 方法:

js
const element = document.getElementById('myElement');
const newDiv = document.createElement('div');
newDiv.textContent = '这是一个新的片段';
element.appendChild(newDiv);

字符串转DOM

js
function parseHTML(htmlString) {
    const parser = new DOMParser();
    const doc = parser.parseFromString(htmlString, 'text/html');
    return doc.body.firstChild; // 返回第一个子元素
}

const htmlString = '<div><p>Hello, World!</p ></div>';
const domElement = parseHTML(htmlString);
console.log(domElement); // 输出: <div><p>Hello, World!</p ></div>

如有转载或 CV 的请标注本站原文地址