首页 > 代码库 > ajax——dom对xml和html的操作

ajax——dom对xml和html的操作

     上篇文章说到了dom的基础,dom能够操作xml和html,这次主要写利用dom的api去如何去操作xml和html文档。

dom操作xml

     dom操作xml文档之前必须把xml文档装载到xml dom对象,因此须要两个步骤1.利用javascript装载xml文档。2.dom来操作装载后的xml文档。

     利用javascript装载xml文档也能够分为:1.装载同域的xml文件。2.装载一段表示xml字符串。

/* 
 * 封装IE和firefox类浏览器中装载同域xml文件和xml字符串的方法,返回的是xml对象dom对象中的根元素节点
 * @param flag true装载xml的文件,false表达式装载xml字符串
 * @param xmldoc flag为false装载xml文件的路径,flag为false表示xml字符串
 */
function loadXML(flag,xmldoc){
    if (window.ActiveXObject) {
        //IE浏览器
        var activexName = ["MSXML2.DOMDocument", "Miscrosoft.XmlDom"];
        var xmlObj;
        for (var i = 0; i < activexName.length; i++) {
            try {
                xmlObj = new ActiveXObject(activexName[i]);
                break;
            } catch (e) {

            }
        }

        if (xmlObj) {
            //同步方式装载xml数据
            xmlObj.async = false;
            if (flag) {
                //装在xml文件
                xmlObj.load(xmldoc);
            } else {
                //装载xml的字符串
                xmlObj.loadXML(xmldoc);//解析一个 XML 标签字符串来组成该文档
            }
            //返回根元素节点
            return xmlObj.documentElement;
        } else {
            alert("装载xml文档的对象创建失败。

"); return null; } } else if (document.implementation.createDocument) { //创建一个新 Document 对象和指定的根元素。 //针对firfox浏览器 var xmlObj; if (flag) { //装载xml文件 xmlObj = document.implementation.createDocument("", "", null);//创建一个新 Document 对象和指定的根元素。 if (xmlObj) { //同步方式装载 xmlObj.async = false; xmlObj.load(xmldoc); return xmlObj.documentElement; } } else { //装载xml的字符串 xmlObj = new DOMParser(); //DOMParser 对象解析 XML 文本并返回一个 XML Document 对象 var docRoot = xmlObj.parseFromString(xmldoc, "text/xml");//解析 XML 标记 return docRoot.documentElement; } } alert("装载xml文档的对象创建失败。"); return null; }

      xml文档

<?xml version="1.0" encoding="UTF-8"?>
<books>
    <book>
        <author>Peter</author>
        <name>Hello Ajax</name>
    </book>
    <book>
        <author>Jack</author>
        <name>Ajax Puzzle</name>
    </book>
</books>
     dom操作xml文档

            function test(){
                var rootElement=loadXML(true,"TestBook.xml");  //装载xml文档,并返回xml dom对象的根元素节点
                var rootDocument=rootElement.parentNode;  //找到父节点
                var bookElement=rootDocument.createElement("book");//创建book节点
                var textNode=rootDocument.createTextNode("AJAX Hello");
                bookElement.appendChild(textNode);  //在bookElement后加入文本节点
                rootElement.appendChild(bookElement);//在文本节点后加入
                var bookElements=rootElement.getElementsByTagName("book");  //返回全部的book节点
                alert("");
            }

dom操作html

     html文档

<html>
    <head>
        <title>TODO supply a title</title>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
    </head>
    <body>
        <input type="button" value="http://www.mamicode.com/TestDomApi" onclick="testDomApi()"/>
        <div id="div1">123123</div>
        <input type="text" id="inputtext"/>
        <div id="div2">
            456
            <div>
                789
            </div>
        </div>
        <input type="button" value="http://www.mamicode.com/textclick" id="clic"/>
    </body>
</html>

     利用根节点的属性和方法操作html文档。能够创建元素节点,文本节点,元素节点。

                //获取根元素节点
                var htmlrootElement=document.documentElement;
                //获取指定的元素节点
                var divNode=document.getElementById("div1");
                //获取整个页面的div元素节点
                var divNodes=document.getElementsByTagName("div");
                //创建元素节点
                var newDivNode=document.createElement("div");
                //创建文本节点
                var newTextNode=document.createTextNode("aaaaaaaa");

     利用元素节点的属性和方法操作html文档。能够去操作元素节点的属性。

                //返回大写的标签名
                var tagName=divNode.tagName;
                //依据标签名获取元素节点
                var divNode2=document.getElementById("div2");
                var divNodes2=document.getElementsByTagName("div");
                //操作属性
                var inputtext=document.getElementById("inputtext");
                var flag=inputtext.hasAttribute("value");//推断是否有这个属性
                inputtext.setAttribute("value","textTest");//设置属性
                var textValue=http://www.mamicode.com/inputtext.getAttribute("value");//获取属性值
                inputtext.removeAttribute("value");//移除属性值
                
                //还有一种属性的操作
                inputtext.value="http://www.mamicode.com/121212";
                var textValue2=inputtext.value;
                
                var clic=document.getElementById("clic");
                clic.onclick=function(){alert("12")};

     利用全部节点都拥有的的属性和方法操作html文档。能够管理html文档的全部节点的。 

                var divNode2=document.getElementById("div2");
                var inputtext=document.getElementById("inputtext");               
                //返回元素节点上的包括的属性节点
                var attributs=inputtext.attributes;
                //nodeName nodeValue nodeType
                var inputname=inputtext.nodeName;
                var nodetype=inputtext.nodeType;
                var nodevalue=http://www.mamicode.com/inputtext.nodeValue;"div");
                var text2=document.createTextNode("insert");
                new2.appendChild(text2);
                divNode2.insertBefore(new2,divNode2.firstChild);  //插入子节点并将子节点移动到第一位
                
                var new3=document.createElement("div");
                var text3=document.createTextNode("insert3");
                new3.appendChild(text3);
                divNode2.insertBefore(new3,null);//插入子节点
                divNode2.insertBefore(new3,divNode2.firstChild);  //将子节点移动到第一位
                
                //移除节点
                var remove=divNode2.removeChild(new3);
                //替换节点,用还有一个节点替换前节点的一个节点
                var text4=document.createTextNode("insert4");
                var new4=document.createElement("div");
                new4.appendChild(text4);
                var replace=divNode2.replaceChild(new4,divNode2.firstChild);
                var replace=divNode2.replaceChild(newDivNode,divNode2.firstChild);
                
                //clone节点
                var clone1=divNode2.cloneNode(true);//克隆子节点
                var clone2=divNode2.cloneNode(false);//不克隆子节点

     dom对象对xml文档和html文档的操作,长处是能够在client更高速的。更直接的管理文档中的节点。缺点就是在不同的浏览器中对文档的操作和载入存在这差异。

ajax——dom对xml和html的操作