DOM笔记

  • 常用DOM对象方法
方法 描述
getElementById() 返回带有指定ID的元素。
getElementsByTagName() 返回包含带有指定标签名称的所有元素的节点列表(集合/节点数组)。
getElementsByClassName() 返回包含带有指定类名的所有元素的节点列表。IE5,6,7,8中无效
appendChild() 把新的子节点添加到指定节点。
removeChild() 删除子节点。
replaceChild() 替换子节点。
insertBefore() 在指定的子节点前面插入新的子节点。
createElement() 创建元素节点。
createAttribute() 创建属性节点。
createTextNode() 创建文本节点。
getAttribute() 返回指定的属性值。
setAttribute() 把指定属性设置或修改为指定的值
  • 常用DOM对象属性
属性 描述
innerHTML 获取或者替换元素内容
nodeName 获取节点名称
nodeValue 获取节点的值
nodeType 返回节点的类型,值为1时,节点为元素
  • DOM事件
事件 描述
onclick 点击事件
onload 页面加载
onunload 页面离开
onchange 改变输入
onmouseover 鼠标在元素上
onmouseout 鼠标离开元素
onmousedown 鼠标按下
onmouseup 鼠标松开
  • DOM节点
属性 描述
parentNode 父节点
firstChild 第一个子节点
lastChild 最后一个子节点
  • 兼容性问题
①:childNodes子节点;获取元素的子节点,在获取子节点的时候,子节点元素之间存在空格的话会生成一个空格子
节点,在IE6,7,8中会清除这些空格节点,而IE9+,谷歌,火狐不行;
<!DOCTYPE html>
<html lang="ch-en">
    <head>
        <meta charset="UTF-8">
        <title>test</title>
    </head>
    <body>        
        <ol id="list">
            <li>html</li>
            <li>css</li>
            <li>dom</li>
        </ol>
        <script>
            var list = document.getElementById("list");
            var list_child = list.childNodes; //获取ol中所有的子元素
            console.log("ol中共有" + list_child.length + "个元素,分别是");
            for(var i = 0; i < list_child.length; i++) {
                console.log(list_child[i].tagName);
            }
        </script>
    </body>
</html>
该例子中在控制台输出:
谷歌

 

 IE6,7,8

 

 IE9

 

 解决兼容的问题,通过每个子节点的nodeType来判断,如果子节点是元素的话、那么他的nodeType值就为1;

<!DOCTYPE html>
<html lang="ch-en">
    <head>
        <meta charset="UTF-8">
        <title>test</title>
    </head>
    <body>        
        <ol id="list">
            <li>html</li>
            <li>css</li>
            <li>dom</li>
        </ol>
        <script>
            var list = document.getElementById("list");
            var list_child = list.childNodes; //获取ol中所有的子元素
            var arr=[];
            for(var i=0;i<list_child.length;i++){
                if(list_child[i].nodeType==1){
                    arr.push(list_child[i]);                    
                }                
            }
            console.log(arr);
            console.log(list_child);
        </script>
    </body>
</html>
控制台输出:
IE6,7,8

 

 

  IE9+

 

 

 

posted @ 2020-03-17 02:06  sjzhen  阅读(62)  评论(0编辑  收藏  举报