JS(六)DOM模型之节点

一、简介

通过js dom找到某个元素,对该元素增加子节点,或删除该元素的子节点。

二、示例

1.动态增加和删除节点元素

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta content="text/css" charset="utf-8" />
<style>
button {
	width: 100px;
	height: 50px;
	background:GREEN;
}
div{
	width:1500px;
	height:500px;
	background:red;
	margin-top:100px;
}
</style>
</head>
<body>
	<button  onclick="addEle()">添加</button>
	<button  onclick="deleteEle()">删除</button>
	<div id="div1">
	   <p id="p0">段落1</p>
	</div>
</body>
<script>
var x= 0;   //定义一个全局的变量
function addEle(){
    var ele = document.createElement("p");
    var node = document.createTextNode("这个是一个段落");
    x++;
    ele.id="p" +x;  //对该节点元素设置id
    ele.style.color="white";//设置节点元素的颜色
    ele.appendChild(node);

    var ele_parent = document.getElementById("div1");
    ele_parent.appendChild(ele);
}
function deleteEle(){
    var ele_parent = document.getElementById("div1");
    var ele_child = document.getElementById("p"+x);
    x--;
    ele_parent.removeChild(ele_child);
}
</script>
</html>

运行效果:

2.动态添加多个节点

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta content="text/css" charset="utf-8" />
<style>
button {
	width: 100px;
	height: 50px;
	background: GREEN;
}

div {
	width: 500px;
	height: 3500px;
	background: red;
	margin-top: 100px;
}
</style>
</head>
<body>
	<button onclick="addEle()">添加</button>
	<button onclick="deleteEle()">删除</button>
	<div id="div1"></div>
</body>
<script>
/**
 * <div>
 *      <img src="./header" width="500" height="100" />
 *      <br/>
 *      <a href="http://xxx">风景图片</a>
 * </div>
 */
var x= 0;   //定义一个全局的变量
function addEle(){
    x++;
    var ele = document.createElement("img");//创建img节点
    ele.id="img" +x;  //对该节点元素设置id
    ele.src="./header.jpg";
    ele.width="500";
    ele.height="100";

    var eleBr=document.createElement("br");//创建br节点
    eleBr.id="br" +x;

    var ele2 = document.createElement("a");//创建a节点
    ele2.id="a" + x;
    ele2.href="http://www.baidu.com";
    var node2 = document.createTextNode("风景图片"+x);
    ele2.appendChild(node2);

    var ele_parent = document.getElementById("div1");
    ele_parent.appendChild(ele);
    ele_parent.appendChild(eleBr);
    ele_parent.appendChild(ele2);

}
function deleteEle(){
    var ele_parent = document.getElementById("div1");
    var ele_child = document.getElementById("img"+x);
    var ele_child2=document.getElementById("br" +x);
    var ele_child3 = document.getElementById("a" +x);
    ele_parent.removeChild(ele_child3);
    ele_parent.removeChild(ele_child2);
    ele_parent.removeChild(ele_child);
    x--;

}
</script>
</html>

运行效果:

时间: 2024-10-25 16:41:38

JS(六)DOM模型之节点的相关文章

JS(四)DOM模型之属性样式

一.DOM模型 1.简介 DOM模型:文档对象模型,Document Object Model. DOM何时创建:当网页被加载的时候,浏览器就会创建页面的文档对象模型. 2.作用 通过DOM模型,用户可以修改HTML元素属性和样式,增减HTML元素,响应HTML元素的事件. 二.常用JS DOM功能 1.输出流:document.write(),动态创建页面输出内容. 2.改变标签内容:document.getElementById("id").innerHTML="&quo

5月25日-js操作DOM遍历子节点

一.遍历节点 遍历子节点 children();//获取节点的所有直接子类 遍历同辈节点 next(); prev(); siblings();//所有同辈元素 *find(); 从后代元素中查找匹配的 filter(); 过滤查找 each() 遍历节点 $("li").each(function(i,ele){ //alert($(ele).html()); }); 二.css DOM操作 三.表单校验 表单选择器

js操作DOM对象(节点的增删改)

<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title>节点的增删改</title> </head> <body> <ul> <li>大家辛苦了1</li> <li>大家辛苦了2</li> <li>大家辛苦了3<

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

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

js之正则、表单验证、dom模型

正则:规则 语法 var a=/表达式/ 输入的值要包含表达式 var a1 = new RegExp('表达式') 检索 ---表达式.test(输入的值) 返还boolean类型 正则符号 (对于多个符号进行正则,用()) ^ ---输入的值以符号后的字符为第一位 $ ---以符号前的字符为结尾 +---- 符号前的字符可以出现多个 *--- 符号前的字符可以出现任意次数 ?--- 符号前字符可以出现0次 或者1次 {n}---符号前字符必须可以出现n次 ,但是要加开始,结尾 {n,}---

JS 操作Dom节点之样式

为了提高用户体验,我们经常会动态修改Dom节点的样式,各种浏览器差异比较大,我们如何应对?不断尝试,不断总结~! 1. style.getComputedStyle.currentStyle 内嵌样式: <!--body --><div style="width: 30px;background-color: #ff6a00;">我就是傻里傻气的,完全素颜!</div> 1 //内联样式优先级最高,通过style获取的样式是最准确的 2 var el

原生JS的DOM节点操作

DOM(Document Object Model/文档对象模型)是针对HTML和XML文档的一个API.DOM节点树:在文档中出现的空格.回车.标签.注释.文本.doctype.标签等都属于DOM节点. 操作DOM节点的方式无非就是:创建.添加(插入).移除.替换.查找(获取).克隆DOM节点. 创建文本节点:var newText = document.createTextNode('文本节点');创建标签节点:var newNode = document.createElement('di

js中DOM 节点的一些操作方法

什么是DOM DOM:文档对象模型.DOM 为文档提供了结构化表示,并定义了如何通过脚本来访问文档结构.目的其实就是为了能让js操作html元素而制定的一个规范. DOM就是由节点组成的. 解析过程 HTML加载完毕,渲染引擎会在内存中把HTML文档,生成一个DOM树,getElementById是获取内中DOM上的元素节点.然后操作的时候修改的是该元素的属性. DOM树(一切都是节点) DOM的数据结构如下: 上图可知,在HTML当中,一切都是节点:(非常重要) 元素节点:HMTL标签. 文本

原生JS获取DOM 节点到浏览器顶部的距离或者左侧的距离

关于js获取dom 节点到浏览器顶/左部的距离,Jquery里面有封装好的offset().top/offset().left,只到父级的顶/左部距离position().top/position().left: 原生写的话就是用获取节点,do while循环就可以了.代码如下 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta