首页 > 代码库 > 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()"/>>利用根节点的属性和方法操作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");//获取属性值>利用所有节点都拥有的的属性和方法操作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;>dom对象对xml文档和html文档的操作,优点是可以在客户端更快速的,更直接的管理文档中的节点。缺点就是在不同的浏览器中对文档的操作和加载存在这差异。
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。