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="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="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=inputtext.getAttribute("value");//获取属性值
inputtext.removeAttribute("value");//移除属性值 //还有一种属性的操作
inputtext.value="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=inputtext.nodeValue; //返回全部子节点
var childs=divNode2.childNodes;
//获取父节点
var parent=divNode2.parentNode;
//获取第一个节点和最后一个节点
var first=divNode2.firstChild;
var last=divNode2.lastChild;
//获取兄弟节点
var next=divNode2.nextSibling; //上一个兄弟节点
var prev=divNode2.previousSibling;//下一个兄弟节点 //推断是否有子节点
var flag2=divNode2.hasChildNodes(); //追加节点
var new2=document.createElement("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的操作的更多相关文章
- 使用DOM进行xml文档的crud(增删改查)操作<操作详解>
很多朋友对DOM有感冒,这里我花了一些时间写了一个小小的教程,这个能看懂,会操作了,我相信基于DOM的其它API(如JDOM,DOM4J等)一般不会有什么问题. 后附java代码,也可以下载(可点击这 ...
- Android之DOM解析XML
一.DOM解析方法介绍 DOM是基于树形结构的节点或信息片段的集合,允许开发人员使用DOM API遍历XML树,检索所需数据.分析该结构通常需要加载整个文档和构造树形结构,然后才可以检索和更新节点信息 ...
- 【JAVA解析XML文件实现CRUD操作】
一.简介. 1.xml解析技术有两种:dom和sax 2.dom:Document Object Model,即文档对象模型,是W3C组织推荐的解析XML的一种方式. sax:Simple API f ...
- xml语法、DTD约束xml、Schema约束xml、DOM解析xml
今日大纲 1.什么是xml.xml的作用 2.xml的语法 3.DTD约束xml 4.Schema约束xml 5.DOM解析xml 1.什么是xml.xml的作用 1.1.xml介绍 在前面学习的ht ...
- C# 使用XmlDocument类对XML文档进行操作
原创地址:http://www.cnblogs.com/jfzhu/archive/2012/11/19/2778098.html 转载请注明出处 W3C制定了XML DOM标准.很多编程语言中多提供 ...
- AJAX的来龙去脉(由来)-如何被封装出来的--ajax发送异步请求(四步操作)
<黑马程序员_超全面的JavaWeb视频教程vedio\JavaWeb视频教程_day23_ajax> \JavaWeb视频教程_day23_ajax\day23ajax_avi\14.打 ...
- dom解析xml随笔
1.dom解析jar包准备: dom解析需用到dom4j的jar包,比如我在项目中用到的的是dom4j-1.6.1jar,因为项目用的是MAVEN,所以可直接到maven中央库去搜索相关pom坐标配置 ...
- 从零开始学 Web 之 DOM(一)DOM的概念,对标签操作
大家好,这里是「 Daotin的梦呓 」从零开始学 Web 系列教程.此文首发于「 Daotin的梦呓 」公众号,欢迎大家订阅关注.在这里我会从 Web 前端零基础开始,一步步学习 Web 相关的知识 ...
- 使用DOM解析xml文件
使用DOM解析xml文件 要解析的xml文件如下: <?xml version="1.0" encoding="UTF-8"?> <Langu ...
随机推荐
- 深入了解SEO
为什么要SEO,SEO的作用是什么?SEO(Search Engine Optimization)是为了让自己的IT产品优先能被搜索引擎找到,通过搜索引擎搜索推荐给网民浏览(特点就是精准找到用户群体) ...
- Deep Android Malware Detection小结
题目:Deep Android Malware Detection 作者:Niall McLaughlin, Jesus Martinez del Rincon, BooJoong Kang 年份:2 ...
- [python IO学习篇] [打开包含中文路径的文件]
https://my.oschina.net/mcyang000/blog/289460 打开路径含有中文的文件时,要注意: 1 在windows对文件名编码是采用gbk等进行编码保存,所以要将文 ...
- [转]netstat -tnl 列出监听中的连接,查看端口是否开启
任何网络服务的后台进程都会打开一个端口,用于监听接入的请求. 这些正在监听的套接字也和连接的套接字一样,也能被 netstat 列出来. 参数 tnl, 现在我们可以看到处于监听状态的 TCP 端口和 ...
- [译]__main__ 顶级脚本环境
'main'是其中顶级代码执行的范围的名称.一个模块的__name__可以从标准输入,脚本,或从一个交互式命令行中等方式被设置成等于'main'. 一个模块可以发现它是否是通过检查自身在主运行范围__ ...
- mq类----2
手动应答方式 使用get my_consumer.php 消费者 生产者和上一篇 一样 <?php /** * Created by PhpStorm. * User: brady * Dat ...
- 【bzoj1604】[Usaco2008 Open]Cow Neighborhoods 奶牛的邻居 旋转坐标系+并查集+Treap/STL-set
题目描述 了解奶牛们的人都知道,奶牛喜欢成群结队.观察约翰的N(1≤N≤100000)只奶牛,你会发现她们已经结成了几个“群”.每只奶牛在吃草的时候有一个独一无二的位置坐标Xi,Yi(l≤Xi,Yi≤ ...
- Code Jam 2017 Round 1A Problem B. Ratatouille
传送门 分析 首先把包(package)的克数 $Q_{ij}$ 转化成区间 $[\lceil Q_{ij}/(1.1 r_i )\rceil, \lfloor Q_{ij}/(0.9 r_i)\rf ...
- kali2 install Nessus
注册: https://www.tenable.com/products/nessus-home 安装: 设置登录用户名,密码,输入注册码:
- vim 翻页命令记录
vim命令: ctrl-f:往前翻一页(forward) ctrl-b:往后翻一页(backward) ctrl-d:往下翻半页(down) ctrl-u:往上翻半页(up)