AJAX开发简略续一(3)

2005/12/20 23:07:03


阅读全文(2706) | 回复(0) | 编辑 | 精华

例子2 – sample3_2.htm: 接下来使用firstChile、lastChild、nextSibling、previousSibling遍历整个文档树。修改一下countTotalElement函数,其他跟sample3_1.htm一样: function countTotalElement(node) { //参数node是一个Node对象        var total = 0;        if(node.nodeType == 1) { //检查node是否为Element对象               total++;                 //如果是,计数器加1               elementName = elementName + node.tagName + "\r\n"; //保存标记名        }        var childrens = node.childNodes;         //获取node的全部子节点        for(var m=node.firstChild; m!=null;m=m.nextSibling) {               total += countTotalElement(m); //在每个子节点上进行递归操作        }        return total; } B、搜索文档中特定的元素 在使用DOM的过程中,有时候需要定位到文档中的某个特定节点,或者具有特定类型的节点列表。这种情况下,可以调用Document对象的getElementsByTagName()和getElementById()方法来实现。 document.getElementsByTagName()返回文档中具有指定标记名的全部Element节点数组(也是NodeList类型)。Element出现在数组中的顺序就是他们在文档中出现的顺序。传递给getElementsByTagName()的参数忽略大小写。比如,想定位到第一个<table>标记,可以这样写:document.getElementsByTagName(“table”)[0]。例外的,可以使用document.body定位到<body>标记,因为它是唯一的。 getElementsByTagName()返回的数组取决于文档。一旦文档改变,返回结果也立即改变。相比,getElementById()则比较灵活,可以随时定位到目标,只是要实现给目标元素一个唯一的id属性值。这个我们在《AJAX开发简略》的“级联菜单”例子中已经使用过了。 Element对象也支持getElementsByTagName()和getElementById()。不同的是,搜索领域只针对调用者的子节点。 C、修改文档内容 遍历整棵文档树、搜索特定的节点,我们最终目的之一是要修改文档内容。接下来的三个例子将使用Node的几个常用方法,来演示如何修改文档内容。 例子3 -- sample4_1.htm: 这个例子包含三个文本节点和一个按钮。点击按钮后,三个文本节点和按钮的顺序将被颠倒。程序使用了Node的appendChild()和removeChild()方法。 <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <title>无标题文档</title> <script language="javascript">        function reverseNode(node) { // 颠倒节点node的顺序               var kids = node.childNodes; //获取子节点列表               var kidsNum = kids.length; //统计子节点总数               for(var i=kidsNum-1;i>=0;i--) { //逆向遍历子节点列表                      var c = node.removeChild(kids[i]); //删除指定子节点,保存在c中                      node.appendChild(c); //将c放在新位置上               }        } </script> </head> <body> <p>第一行</p> <p>第二行</p> <p>第三行</p> <p><input type="button" name="reverseGo" value="颠倒" onClick="reverseNode(document.body)"></p> </body> </html> 500)this.width=500'>500)this.width=500'>              例子4-- sample4_2.htm: 例子1通过直接操作body的子节点来修改文档。在HTML文档中,布局和定位常常通过表格<table>来实现。因此,例子4将演示操作表格内容,将表格的四个单元行顺序颠倒。如果没有使用<tbody>标签,则<table>把全部的<tr>当做是属于一个子节点<tbody>,所以我们采用数组缓存的方式,把行数据颠倒一下。这个例子同时也演示了如何使用DOM创建表格单元行。 <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <title>无标题文档</title> <script language="javascript"> function reverseTable() {        var node = document.getElementsByTagName("table")[0]; //第一个表格        var child = node.getElementsByTagName("tr"); //取得表格内的所有行        var newChild = new Array(); //定义缓存数组,保存行内容        for(var i=0;i<child.length;i++) {               newChild[i] = child[i].firstChild.innerHTML;        }        node.removeChild(node.childNodes[0]); //删除全部单元行        var header = node.createTHead(); //新建表格行头        for(var i=0;i<newChild.length;i++) {               var headerrow = header.insertRow(i); //插入一个单元行               var cell = headerrow.insertCell(0); //在单元行中插入一个单元格               //在单元格中创建TextNode节点               cell.appendChild(document.createTextNode(newChild[newChild.length-i-1]));        } } </script> </head> <body> <table width="200" border="1" cellpadding="4" cellspacing="0">     <tr>         <td height="25">第一行</td>     </tr>     <tr>         <td height="25">第二行</td>     </tr>     <tr>         <td height="25">第三行</td>     </tr>     <tr>         <td height="25">第四行</td>     </tr> </table> <br> <input type="button" name="reverse" value="开始颠倒" onClick="reverseTable()"> </body> </html>      500)this.width=500'>500)this.width=500'>

Qr

Posted by Qr on 2005/12/20 23:07:03


发表评论:
昵称:
密码:
主页:
标题:
验证码:  (不区分大小写,请仔细填写,输错需重写评论内容!)
站点首页 | 联系我们 | 博客注册 | 博客登陆

Sponsored By W3CHINA
W3CHINA Blog 0.8 Processed in 0.750 second(s), page refreshed 144795368 times.
《全国人大常委会关于维护互联网安全的决定》  《计算机信息网络国际联网安全保护管理办法》
苏ICP备05006046号