HTML DOM (文档对象模型)
当网页被加载时,浏览器会创建页面的文档对象模型(Document Object Model)。
HTML DOM 模型被构造为对象的树。
通过可编程的对象模型,JavaScript 获得了足够的能力来创建动态的 HTML。
- JavaScript 能够改变页面中的所有 HTML 元素
- JavaScript 能够改变页面中的所有 HTML 属性
- JavaScript 能够改变页面中的所有 CSS 样式
- JavaScript 能够对页面中的所有事件做出反应
-
改变 HTML 属性
如需改变 HTML 元素的属性,请使用这个语法:
document.getElementById(id).attribute=new value
实例
本例改变了 <img> 元素的 src 属性:
<!DOCTYPE html> <html> <body> <img id="image" src="smiley.gif"> <script> document.getElementById("image").src="landscape.jpg"; </script> </body> </html>
-
改变 HTML 样式
如需改变 HTML 元素的样式,请使用这个语法:
document.getElementById(id).style.property=new style
例子 1
下面的例子会改变 <p> 元素的样式:
<p id="p2">Hello World!</p> <script> document.getElementById("p2").style.color="blue"; </script>
- 执行点击事件
- <button type="button" οnclick="my()">点击这里</button></body>
<button type="button" οnclick="document.getElementById('demo').style.color='red'">点击这里</button></body>
- <input type="button" value="隐藏文本" οnclick="document.getElementById('demo').style.visibility='hidden'" />
<input type="button" value="显示文本" οnclick="document.getElementById('demo').style.visibility='visible'" />
HTML 事件属性
如需向 HTML 元素分配 事件,您可以使用事件属性。
向 button 元素分配 onclick 事件:
<button οnclick="displayDate()">点击这里</button>
<h1 οnclick="this.innerHTML='谢谢!'">请点击该文本</h1>
2.HTML DOM 允许您通过使用 JavaScript 来向 HTML 元素分配事件:
向 button 元素分配 onclick 事件:
<p>点击按钮就可以执行 <em>displayDate()</em> 函数。</p>
<button id="myBtn">点击这里</button>
<script>
document.getElementById("myBtn").οnclick=function(){displayDate()};
function displayDate()
{
document.getElementById("demo").innerHTML=Date();
}
</script>
<p id="demo"></p>
</body>
onload某个元素加载完成时调用,
onunload 事件会在用户离开页面时被触发。
onload 事件可用于检测访问者的浏览器类型和浏览器版本,并基于这些信息来加载网页的正确版本。
onload 和 onunload 事件可用于处理 cookie。
onchange 事件,当改变事件状态时,常结合对输入字段的验证来使用。
<body>
<div οnmοuseοver="mOver(this)" οnmοuseοut="mOut(this)" style="background-color:green;width:120px;height:20px;padding:40px;color:#ffffff;">把鼠标移到上面</div>
<script>
function mOver(obj)
{
obj.innerHTML="谢谢"
}
function mOut(obj)
{
obj.innerHTML="把鼠标移到上面"
}
</script>
</body>
</html>
-
onfocus文本框获得焦点时调用;
//====创建新的html元素=================
向 HTML DOM 添加新元素,您必须首先创建该元素(元素节点),然后向一个已存在的元素追加该元素。
<p id="p1">这是一个段落。</p>
<p id="p2">这是另一个段落。</p>
</div>
<script>
function myadd(){
var para=document.createElement("p");//创建新的元素
var node=document.createTextNode("这是新段落。");//穿件元素的文本节点
para.appendChild(node);//向p元素追加这个文本节点
var element=document.getElementById("div1");//获得div元素
element.appendChild(para);//向div元素后追加p元素
}
</script>
<button type="button" οnclick="myadd()">点击这里添加一个p段落</button></body>
删除已有的 HTML 元素
如需删除 HTML 元素,您必须首先获得该元素的父元素:
<div id="div1">
<p id="p1">这是一个段落。</p>
<p id="p2">这是另一个段落。</p>
</div>
<script>
function myadd(){
var para=document.createElement("p");
var node=document.createTextNode("这是新段落。");
para.appendChild(node);
var element=document.getElementById("div1");
element.appendChild(para);
}
function mydel(){
var parent=document.getElementById("div1");
var child=document.getElementById("p1");
parent.removeChild(child);
//或者可以写成下面的
找到您希望删除的子元素,然后使用其 parentNode 属性来找到父元素:
var child=document.getElementById("p1"); child.parentNode.removeChild(child);
}
</script>
<button type="button" οnclick="myadd()">点击这里添加一个p段落</button></body>
<button type="button" οnclick="mydel()">点击这里添加删除id为p1段落</button></body>