本文介绍了JavaScript中使用DOM来控制HTML元素的相关资料,文章内容主要包括关于DOM,HTML,获取Name,获取元素,创建元素节点,控制子节点,创建文本节点,插入节点,获取网页尺寸等等,文章来自网络,初学JavaScriptde的朋友请参考。
1.getElementsByName():获取name.
hello
hello
hello
function getName(){
var count=document.getElementsByName("pn");
alert(count.length);
var p=count[2];
p.innerHTML="world";
}
结果:界面打印出三个hello,并且伴有一个提示框“3”,当点击确定后,界面显示的内容变为hello hello world
2.getElementsByTagName():获取元素。
hello
hello
hello
function getName(){
var count=document.getElementsByTagName("p");
alert(count.length);
var p=count[2];
p.innerHTML="world";
}
结果:界面打印出三个hello,并且伴有一个提示框“3”,当点击确定后,界面显示的内容变为hello hello world
3.getAttribute():获取元素属性。
function getAttr1(){
var anode=document.getElementById("aid");
var attr=anode.getAttribute("id");
alert("a的ID是:"+attr);
}
function getAttr2(){
var anode=document.getElementById("aid");
var attr=anode.getAttribute("title");
alert("a的title内容是:"+attr);
}
getAttr1();
getAttr2();
结果:弹出提示框“a的ID是:aid”.点击确定后,弹出提示框“a的title内容是:得到a的标签属性”。
4.setAttribute()设置元素属性。
function setAttr(){
var anode=document.getElementById("aid2");
anode.setAttribute("title","动态设置a的title属性");
var attr=anode.getAttribute("title");
alert("动态设置的title值为:"+attr);
}
setAttr();
结果:弹出提示框“动态设置的title值为:动态设置a的title属性”。
5.childNodes():访问子节点。
- 1
- 2
- 3
function getChildNode(){
var childnode=document.getElementsByTagName("ul")[0].childNodes;
alert(childnode.length);
alert(childnode[0].nodeType);
}
getChildNode();
结果:界面打印出.1 .2 .3弹出对话框“3”,按确定后弹出“1”。
6.parentNode():访问父节点。
function getParentNode(){
var div=document.getElementById("pid");
alert(div.parentNode.nodeName);
}
getParentNode();
结果:弹出提示框:DIV.
7.createElement():创建元素节点。
function createNode(){
var body=document.body;
var input=document.createElement("input");
input.type="button";
input.value="按钮";
body.appendChild(input);//插入节点
}
createNode();
结果:出现一个按钮。
8.createTextNode():创建文本节点。
function createNode(){
var element = document.createElement("div");
element.className = "message";
var textNode = document.createTextNode("Hello world!");
element.appendChild(textNode);
document.body.appendChild(element);
}
createNode();
代码分析:这个例子创建了一个新
元素并为它指定了值为“message”的class特性。然后,又创建了一个文本节点,并将其添加到前面创建的元素中。最后一步,就是将这个元素添加到了文档中的元素中,这样可以在浏览器中看到新创建的元素和文本节点了。
结果:页面显示hello world。
9.insertBefore():插入节点。
p元素
function addNode(){
var div=document.getElementById("div");
var node=document.getElementById("pid");
var newnode=document.createElement("p");
newnode.innerHTML="动态插入一个p元素";
div.insertBefore(newnode,node);
}
addNode();
结果:界面打印出:动态插入一个p元素
10.removeChild():删除节点。
p元素
function removeNode(){
var div=document.getElementById("div");
var p=div.removeChild(div.childNodes[1]);
}
removeNode();
结果:界面什么也没显示。
11.offsetHeight; .scrollHeight:网页尺寸
function getSize(){
var width=document.documentElement.offsetWidth||document.body.offsetWidth;//解决兼容问题
var height=document.documentElement.offsetHeight||document.body.offsetHeight;
alert(width+","+height);
}
getSize();