js怎样添加、移除、移动、复制、创建和查找节点

本文详细介绍了如何使用JavaScript进行DOM操作,包括创建新节点、添加、移除、替换节点等方法,并展示了如何利用这些方法实现节点的前后插入及元素内部前后插入等功能。

(1)创建新节点

    

var para=document.createElement("p"); //创建新的 <p> 元素
var node=document.createTextNode("这是新段落。"); //创建了一个文本节点
para.appendChild(node); //向 <p> 元素追加这个文本节点

var element=document.getElementById("div1");//向一个已有的元素追加这个新元素
element.appendChild(para); //向这个已有的元素追加新元素

(2)添加、移除、替换、之前插入、之后插入、复制

      appendChild()

      removeChild()

      replaceChild()

      insertBefore()

      insertAfter()

      cloneNode() 

(3)查找

      document.getElementsByTagName("")    //通过标签名称

      document.getElementsByName("")    //通过元素的Name属性的值

      document.getElementById("")    //通过元素Id,唯一性

      document.getElementsByClassName("");  //通过类查找

      document.querySelector("")


 <div class="box"></div>
<div id="box-one">
<p id="p1">p1p1p1p1</p>
</div>

<script type="text/javascript">
//创建节点
var parent=document.createElement("div");
var text=document.createTextNode("这是第一个使用createTexxtNote创建的文本");
parent.appendChild(text);
//console.log(parent)




//向元素中添加节点
var grandpa=document.querySelector(".box");
//console.log(grandpa)
grandpa.appendChild(parent);






//向元素后 添加节点
var p=document.createElement('p');
var html=document.createTextNode("在元素后边添加的代码");
p.appendChild(html)
insertAfter(p,grandpa);
function insertAfter( newElement, targetElement ){ 
// newElement是要追加的元素 targetElement 是指定元素的位置 
var grandpa = targetElement.parentNode; // 找到指定元素的父节点 
if( grandpa.lastChild == targetElement ){ // 判断指定元素的是否是节点中的最后一个位置 如果是的话就直接使用appendChild方法 
grandpa.appendChild( newElement, targetElement ); 
}else{ 
grandpa.insertBefore( newElement, targetElement.nextSibling ); 
}; 
}; 






//向元素前 添加节点insertBefore
var h6=document.createElement("h6");
var htext=document.createTextNode("在元素之前添加h6");
h6.appendChild(htext);
//console.log(htext);
console.log(grandpa)
parent.parentNode.insertBefore(h6,parent);//运用同级的方法在同级元素之前插入







//元素内部的前面插入节点insertBefore
function inhoutEle() { 
var oTest = document.getElementById("box-one"); 
var newNode = document.createElement("div"); 
var reforeNode = document.getElementById("p1"); 
newNode.innerHTML = " 元素内部的前面插入节点 "; 
oTest.insertBefore(newNode,reforeNode); // 新建的元素节点插入到 id为p1的元素前面 
} inhoutEle()


//元素内部的后面插入节点appendChild
function inqianEle() { 
var oTest = document.getElementById("box-one"); 
var newNode = document.createElement("div"); 
var reforeNode = document.getElementById("p1"); 
newNode.innerHTML = " 元素内部的前面插入节点 "; 
oTest.appendChild(newNode,reforeNode); // 新建的元素节点插入到 id为p1的元素前面 
} inqianEle()
</script>

 

### 使用 JavaScript DOM API 对节点的操作 #### 创建节点 通过 `document` 提供的方法可以方便地创建不同类型的节点: - **创建文档片段** 文档片段用于临时存储多个子节点,在将其一次性添加至DOM树中,减少重绘回流。 ```javascript const fragment = document.createDocumentFragment(); ``` 此方法有助于提高性能并简化批量节点管理[^1]。 - **创建元素节点** 当需要向页面中新增特定标签时使用此法。 ```javascript const element = document.createElement('div'); ``` - **创建文本节点** 若仅需插入纯文本,则应采用这种方式。 ```javascript const textNode = document.createTextNode('Hello World!'); ``` #### 添加节点 为了使新创建节点成为现有结构的一部分,可利用如下几种方式之一: - **追加子节点** 把指定的新节点作为最后一个子项加入目标容器内。 ```javascript parentElement.appendChild(newChild); ``` #### 删除节点 当不再需要某些节点时,可以通过下列手段予以清除: - **移除节点** 取消某元素与其父级之间的关联关系。 ```javascript parentNode.removeChild(childToRemove); ``` #### 替换节点 如果希望用一个新的节点代替现有的某个节点,那么应该这样做: - **替换子节点** 新旧两方互换位置,原位更新显示内容而不改变其所在层次结构。 ```javascript parentNode.replaceChild(newChild, oldChild); ``` #### 插入节点 除了简单的追加外,还可以精确控制新成员的具体摆放地点: - **前置插入** 在参照物之前安插新的兄弟姐妹角色。 ```javascript referenceNode.parentNode.insertBefore(newNode, referenceNode); ``` #### 移动节点 对于已存在于文档中的对象而言,变更其所处方位只需执行一次附加动作即可实现迁移效果。这是因为被重新挂载后的实例会自动断开原先连接点上的联系[^3]。 ```javascript const nodeToMove = document.querySelector('#movable-node'); const destinationContainer = document.querySelector('.target-area'); destinationContainer.appendChild(nodeToMove); ``` #### 复制节点 有时可能想要保留原始副本的同时另起炉灶构建相似布局,这时就需要深浅拷贝技术了: - **克隆节点** 参数决定是否连同后代一起仿造,默认只做表层处理;传入布尔值 true 表明要递归复制整个分支。 ```javascript const clonedElement = originalElement.cloneNode(true); ``` #### 查找节点 最后但同样重要的是定位功能——快速精准获取所需组件的关键技能包: - **按ID检索单个元素** 高效直达唯一标识符对应的个体。 ```javascript const uniqueItem = document.getElementById('unique-id'); ``` - **基于标签名称筛选集合** 收集具有相同标记名的一组实体。 ```javascript const allParagraphs = document.getElementsByTagName('p'); ``` - **依据类样式匹配群组** 找出共享某一CSS类别属性的对象们。 ```javascript const itemsOfClassA = document.getElementsByClassName('class-a'); ``` - **运用选择器语法查询单一/多重结果** 类似于编写CSS规则那样灵活指派条件表达式来进行搜索工作。 ```javascript // 单一最佳匹配 const firstMatchedElm = document.querySelector('.some-class .nested > p'); // 获取所有符合条件者组成的静态 NodeList 列表 const matchedElsList = document.querySelectorAll('[data-type="special"]'); ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值