DOM基础教程之使用DOM


Posted in Javascript onJanuary 19, 2015

在了解DOM(文本对象模型)的框架和节点后,最重要的是使用这些节点处理html网页

对于一个DOM节点node,都有一系列的属性和方法可以使用。常用的有下表。

DOM基础教程之使用DOM

完善:http://www.w3school.com.cn/xmldom/dom_element.asp

1.访问节点

BOM提供了一些边界的方法访问节点,常用的就是getElementsByTagName(),和getElementById()

<script type="text/javascript">

    function searchDOM(){

        var oLi = document.getElementsByTagName("li");

       var j =oLi.length;

       var j2 =oLi[5].tagName;

        var j3 =oLi[0].childNodes[0].nodeValue;

        document.write(j+"<br>"+j2+"<br>"+j3+"<br>");

    }

</script>

<body>

<body onload="searchDOM()">

<div id-"in"></div>

<ul>客户端语言

    <li>HTML</li>

    <li>JavaScript</li>

    <li>CSS</li>

</ul>

<ul>服务器端语言

    <li>ASP.NET</li>

    <li>JSP</li>

    <li>PHP</li>

</ul>

</body>

document.getElementById()

<script type="text/javascript">

    window.onload = function(){

        function findid(){

            var j4 =oli2.tagName;

            document.write(j4);

        }

        var oli2 = document.getElementById("inn");

        oli2.onclick = findid;

    }

</script>

<li id="inn">PHP</li>

 
<html>

<body id="myid" class="mystyle">

<div class="myid2"></div>

<script type="text/javascript">

x=document.getElementsByTagName('div')[0];

document.write("div CSS class: " + x.className);

document.write("<br />");

document.write("An alternate way: ");

document.write(document.getElementById('myid').className);

</script>
</body>

</html>

//id获得className

 2.检测节点类型

 通过节点的nodeType可以检测到节点的类型,该参数一个返回12个整数值。

表达格式如 document.nodeType

正真有用的,还是DOM(一)模型中的模型节点 提到的三种类型

元素节点,文本节点和属性节点

1.元素节点 element node 返回值为 1

2.属性节点 attribute node 返回值为 2

3.文本节点 text node 返回值为 3

<script type="text/javascript">

    window.onload = function(){

        function findid(){

            var j5 =oli2.nodeType;

            document.write("nodeType:"+ j5 +"<br>");

        }

        var oli2 = document.getElementById("inn");

        oli2.onclick = findid;

    }

</script>

<li id="inn">CSS</li>

返回:nodeType:1

这意味着可以对某种节点做单独处理,在搜索节点时非常实用。后面会讲到。

3.利用父子兄关系查找节点

在第一小节访问节点上,利用节点的childNodes属性来访问元素节点包含的文本节点。

本小节利用节点的父子兄关系来查找节点

*利用hasChildNodes和childNodes属性获取该节点包含的所有节点

<head>

    <title>childNodes</title>

    <script language="javascript">

       window.onload = function myDOMInspector(){

            var oUl = document.getElementById("myList");    //获取<ul>标记

            var DOMString = "";

            if(oUl.hasChildNodes()){                        //判断是否有子节点

                var oCh = oUl.childNodes;

                for(var i=0;i<oCh.length;i++)                //逐一查找

                    DOMString += oCh[i].nodeName + "<br>";

            }

            document.write(DOMString);

        }

    </script>

</head>

<body>

<ul id="myList">

    <li>糖醋排骨</li>

    <li>圆笼粉蒸肉</li>

    <li>泡菜鱼</li>

    <li>板栗烧鸡</li>

    <li>麻婆豆腐</li>

</ul>

</body>

 4.DOM获取节点的父节点

    <script language="javascript">

       window.onload = function(){

     var food = document.getElementById("mydearfood");

      document.write(food.parentNode.tagName)

        }

    </script>

</head>

<body>

<ul>

    <li>糖醋排骨</li>

    <li>圆笼粉蒸肉</li>

    <li>泡菜鱼</li>

    <li id="mydearfood">板栗烧鸡</li>

    <li>麻婆豆腐</li>

</ul>

//返回 ul

使用父节点,成功的获得了指定节点的父节点

 5.使用parentNode属性

<head>

    <title>childNodes</title>

    <script language="javascript">

       window.onload = function(){

     var food = document.getElementById("mydearfood");

           var parentElm = food.parentNode;

           while(parentElm.className != "colorful" && parentElm != document.body)

               parentElm = parentElm.parentNode;    //一路往上找

           document.write("tageName:"+parentElm.tagName+"<br>");

           document.write("claaName:"+parentElm.className+"<br>");

           document.write("typeOf:"+typeof(food)+"<br>");

        }

    </script>

</head>

<body>

<div class="colorful">

<ul>

    <span>

    <li>糖醋排骨</li>

    <li>圆笼粉蒸肉</li>

    <li>泡菜鱼</li>

    <li id="mydearfood">板栗烧鸡</li>

    <li>麻婆豆腐</li>

    </span>

</ul>

    </div>

</body><br>//输出<br>//tageName:DIV<br>claaName:colorful<br>typeOf:object

从某个子节点开始,一直向上搜索父节点,直到节点的类名为“colorful”

6.dom的兄弟关系

<head>

    <title>childNodes</title>

    <script language="javascript">

       window.onload = function(){

     var foods = document.getElementById("mydearfood");

     var nextF = foods.nextSibling;

     alert("nextSibling:"+nextF.tagName +"<br>");

        }
    </script>

</head>

<body>

<div class="colorful">

<ul>

    <span>

    <li>糖醋排骨</li>

    <li>圆笼粉蒸肉</li>

    <li>泡菜鱼</li>

    <li id="mydearfood">板栗烧鸡</li>

    <li>麻婆豆腐</li>

         <li>麻婆豆腐</li>

         <li>麻婆豆腐</li>

    </span>

</ul>

    </div>

</body>

利用nextsibling和previousSibling属性访问兄弟节点看上去很好。

但仅仅适用于ie浏览器

为了使用代码有良好的兼容性,就必须使nodeType进行判断

以下做兼容性处理:

<head>

<title>Siblings</title>

<script language="javascript">

function nextSib(node){

    var tempLast = node.parentNode.lastChild;

    //判断是否是最后一个节点,如果是则返回null

    if(node == tempLast)

        return null;

    var tempObj = node.nextSibling;

    //逐一搜索后面的兄弟节点,直到发现元素节点为止

    while(tempObj.nodeType!=1 && tempObj.nextSibling!=null)

        tempObj = tempObj.nextSibling;

    //三目运算符,如果是元素节点则返回节点本身,否则返回null

    return (tempObj.nodeType==1)?tempObj:null;

}

function prevSib(node){

    var tempFirst = node.parentNode.firstChild;

    //判断是否是第一个节点,如果是则返回null

    if(node == tempFirst)

        return null;

    var tempObj = node.previousSibling;

    //逐一搜索前面的兄弟节点,直到发现元素节点为止

    while(tempObj.nodeType!=1 && tempObj.previousSibling!=null)

        tempObj = tempObj.previousSibling;

    return (tempObj.nodeType==1)?tempObj:null;

}

function myDOMInspector(){

    var myItem = document.getElementById("myDearFood");

    //获取后一个元素兄弟节点

    var nextListItem = nextSib(myItem);

    //获取前一个元素兄弟节点

    var preListItem = prevSib(myItem);

    alert("后一项:" + ((nextListItem!=null)?nextListItem.firstChild.nodeValue:null) + " 前一项:" + ((preListItem!=null)?preListItem.firstChild.nodeValue:null) );

}

</script>

</head>

<body onload="myDOMInspector()">

    <ul>

        <li>糖醋排骨</li>

        <li>圆笼粉蒸肉</li>

        <li>泡菜鱼</li>

        <li id="myDearFood">板栗烧鸡</li>

        <li>麻婆豆腐</li>

    </ul>

</body>

7.设置节点属性

<head>

    <title>childNodes</title>

    <script language="javascript">

       window.onload = function(){

           //获取图片

           var imgDataBe = document.getElementsByTagName("img")[0];

           //取得图片的title属性

           imgDataBe.setAttribute("src","02.gif");

           imgDataBe.setAttribute("title","人情坡");

           document.write(imgDataBe.getAttribute("title"));

           document.write(imgDataBe.getAttribute("alt"));

           document.write(imgDataBe.getAttribute("node-data"));

           document.write(imgDataBe.getAttribute("node_data"));

        }

    </script>

</head>

<body>

<div class="colorful">

<img src="01.jpg" title="情人坡" alt="111" node-data="222" node_data="3333">

<img src="01.jpg" title="情人坡22">

</body>

用setAttribute()方法设置节点属性

<head>

        <title>childNodes</title>

        <meta charset="utf-8" />

        <script language="javascript">

            window.onload = function() {

                var bkk = document.getElementById("new5");

                var clickbk = document.getElementById("qiehuan");

                clickbk.onclick = dsqiehuan;

                function dsqiehuan() {

                    bkk.setAttribute("class", "xxx")

                }

            }

        </script>

        <style>

            .xxx{color:#ddd}

        </style>

    </head>

    <body>

        <div id="new5">

            555

        </div>

        <em id="qiehuan">切换</em>

    </body>

8.createElement() 创建节点

    <head>

        <title>childNodes</title>

        <meta charset="utf-8" />

        <script language="javascript">

            window.onload = function() {

        var oP = document.createElement("p");

        var oText = document.createTextNode("使用dom创建节点");

        var oText1 = document.createTextNode("使用dom创建节点123");

        oP.appendChild(oText);

        oP.appendChild(oText1);

        document.body.appendChild(oP);

            }

        </script>

    </head>

    <body>

    <p>这里本来有个P,测试createElement()</p>

    </body>

 9.removeChild移除节点

<head>

        <title>childNodes</title>

        <meta charset="utf-8" />

        <script language="javascript">

            window.onload = function() {

        var oP = document.getElementsByTagName("p")[0];

        oP.parentNode.removeChild(oP);//结尾为 .removeChild(oP),不是.removeChild("oP")

            }

        </script>

    </head>

    <body>

    <p>这里本来有个P,测试createElement()</p>

    </body>

 10.insertBefore() 在特定节点前插入节点

    <head>

        <title>childNodes</title>

        <meta charset="utf-8" />

        <script language="javascript">

            window.onload = function() {

        var oPold = document.getElementsByTagName("p")[0];

        var oPnew = document.createElement("p");

        var oText = document.createTextNode("新节点")

       oPnew.appendChild(oText) ;

        oPold.parentNode.insertBefore(oPnew,oPold);//接收两个参数,一个是新参数,一个是旧节点参数

            }

        </script>

    </head>

    <body>

    <p>这里本来有个P</p>

    </body>

11.在特定的节点之后插入新元素(2015年1月9日补充)

DOM提供的方法只能用insertBefore()在目标元素前加入新的元素,或者利用appendchild()方法在父元素的childNodes末尾加入新的元素(示例:地址)。

而实际中常常用到在某个特定的元素末尾加入新的元素。而DOM方法并没有insertBefore()方法,但是利用现有的知识,完全可以利用现有知识进行编写。

 代码思路如下

    function insertAfter(newElement, targetElement) {

                var oparent = targetElement.parentNode; //找到目标元素的父元素

                if (oparent.lastChild == targetElement) //如果目标是最后一个元素了

                oparent.appendChild(newElement); //直接添加到最后一个元素的后面

                else //插入到下一个元素的父元素节点之前      

                    oparent.insertBefore(newElement, targetElement.nextSibling)

实例:(元素外追加)原来实例:地址

<head>

        <meta charset="utf-8">

        <title></title>

    </head>

    <body onload="interP()">

        <p>第一个</p>

        <p id="target">第二个</p>

        <script type="text/javascript">

            function insertAfter(newElement, targetElement) {

                var oparent = targetElement.parentNode; //找到目标元素的父元素

                if (oparent.lastChild == targetElement) //如果目标是最后一个元素了

                oparent.appendChild(newElement); //直接添加到最后一个元素的后面

                else //插入到下一个元素的父元素节点之前      

                    oparent.insertBefore(newElement, targetElement.nextSibling)

            }

            function interP() {

                var ooParent = document.getElementById("target");

                var oonewP = document.createElement("a");

                oonewP.setAttribute("href","http://www.qq.com");

                var ootextP = document.createTextNode("链接");

                oonewP.appendChild(ootextP);

                insertAfter(oonewP, ooParent);

            }

        </script>

    </body>

 实例:元素内添加

12.添加文档碎片提高执行效率

    <head>

        <title>childNodes</title>

        <meta charset="utf-8" />

        <script language="javascript">

            window.onload = function() {

    var oPold = document.getElementsByTagName("p")[0];

    var aColors = ["red","green","blue","magenta","yellow","chocolate","black","aquamarine","lime","fuchsia","brass","azure","brown","bronze","deeppink","aliceblue","gray","copper","coral","feldspar","orange","orchid","pink","plum","quartz","purple"];

    var oFragment = document.createDocumentFragment();    //创建文档碎片

    for(var i=0;i<aColors.length;i++){

        var oP = document.createElement("p");

        var oText = document.createTextNode(aColors[i]);

        oP.appendChild(oText);

        oFragment.appendChild(oP);        //将节点先添加到碎片中

    }

    //document.body.appendChild(oFragment);    //最后一次性添加到页面

     oPold.parentNode.insertBefore(oFragment,oPold);//结合insertBefore使文档碎片添加到节点之前

            }

        </script>

    </head>

    <body>

    <p>这里本来有个P</p>

    </body>
Javascript 相关文章推荐
jQuery 使用个人心得
Feb 26 Javascript
jQuery 学习6 操纵元素显示效果的函数
Feb 07 Javascript
详解JavaScript中的blink()方法的使用
Jun 08 Javascript
JAVASCRIPT代码编写俄罗斯方块网页版
Nov 26 Javascript
Underscore源码分析
Dec 30 Javascript
用jquery快速解决IE输入框不能输入的问题
Oct 04 Javascript
JS实现页面进入和返回定位到具体位置
Dec 08 Javascript
JS实现微信摇一摇原理解析
Jul 22 Javascript
jQuery绑定事件方法及区别(bind,click,on,live,one)
Aug 14 jQuery
对node通过fs模块判断文件是否是文件夹的实例讲解
Jun 10 Javascript
Vue项目结合Vue-layer实现弹框式编辑功能(实例代码)
Mar 11 Javascript
JavaScript如何实现防止重复的网络请求的示例
Jan 28 Javascript
DOM基础教程之模型中的模型节点
Jan 19 #Javascript
javascript正则表达式使用replace()替换手机号的方法
Jan 19 #Javascript
javascript正则表达式之search()用法实例
Jan 19 #Javascript
jQuery中delegate()方法用法实例
Jan 19 #Javascript
jQuery中die()方法用法实例
Jan 19 #Javascript
jQuery中live()方法用法实例
Jan 19 #Javascript
jQuery中unbind()方法用法实例
Jan 19 #Javascript
You might like
PHP根据IP判断地区名信息的示例代码
2014/03/03 PHP
PHP错误和异长常处理总结
2014/03/06 PHP
ThinkPHP跳转页success及error模板实例教程
2014/07/17 PHP
php判断两个日期之间相差多少个月份的方法
2015/06/18 PHP
PHP上传图片类显示缩略图功能
2016/06/30 PHP
YII2 实现多语言配置的方法分享
2017/01/11 PHP
Laravel5.* 打印出执行的sql语句的方法
2017/07/24 PHP
JavaScript随机排序(随即出牌)
2010/09/17 Javascript
关于用Jquery的height()、width()计算动态插入的IMG标签的宽高的问题
2010/12/08 Javascript
一款Jquery 分页插件的改造方法(服务器端分页)
2011/07/11 Javascript
JavaScript中的比较操作符&gt;、=、
2014/12/31 Javascript
javascript Slip.js实现整屏滑动的手机网页
2015/11/25 Javascript
第五篇Bootstrap 排版
2016/06/21 Javascript
解析如何利用iframe标签以及js制作时钟
2016/12/08 Javascript
微信小程序使用wxParse解析html的方法教程
2018/07/06 Javascript
使用jQuery给Table动态增加行、清空table的方法
2018/09/05 jQuery
webpack配置proxyTable时pathRewrite无效的解决方法
2018/12/13 Javascript
Vue动态组件与异步组件实例详解
2019/02/23 Javascript
vscode 配置vue+vetur+eslint+prettier自动格式化功能
2020/03/23 Javascript
vue实现一个6个输入框的验证码输入组件功能的实例代码
2020/06/29 Javascript
js实现列表按字母排序
2020/08/11 Javascript
微信小程序实现天气预报功能(附源码)
2020/12/10 Javascript
python 图片验证码代码分享
2012/07/04 Python
Python continue语句用法实例
2014/03/11 Python
Python加密方法小结【md5,base64,sha1】
2017/07/13 Python
Python探索之ModelForm代码详解
2017/10/26 Python
浅析python继承与多重继承
2018/09/13 Python
Python格式化字符串f-string概览(小结)
2019/06/18 Python
python图片指定区域替换img.paste函数的使用
2020/04/09 Python
python3爬虫中引用Queue的实例讲解
2020/11/24 Python
英国第一家领先的在线处方眼镜零售商:Glasses Direct
2018/02/23 全球购物
软件部经理岗位职责范本
2014/02/25 职场文书
餐饮食品安全责任书
2015/01/29 职场文书
龙猫观后感
2015/06/09 职场文书
运动会3000米加油稿
2015/07/21 职场文书
http通过StreamingHttpResponse完成连续的数据传输长链接方式
2022/02/12 Python