js如何访问xml
js如何访问xml
js如何访问xml一、xml节点对象属性
childNodes—返回节点到子节点的节点列表
firstChild—返回节点的首个子节点。
lastChild—返回节点的最后一个子节点。
nextSibling—返回节点之后紧跟的同级节点。
nodeName—返回节点的名字,根据其类型。
nodeType—返回节点的类型。
nodeValue—设置或返回节点的值,根据其类型。
ownerDocument—返回节点的根元素(document对象)。
parentNode—返回节点的父节点。
previousSibling—返回节点之前紧跟的同级节点。
二、xml节点对象的方法
appendChild()—向节点的子节点列表的结尾添加新的子节点。
cloneNode()—复制节点。
hasChildNodes()—判断当前节点是否拥有子节点。
insertBefore()—在指定的子节点前插入新的子节点。
normalize()—合并相邻的Text节点并删除空的Text节点。
removeChild()—删除(并返回)当前节点的指定子节点。
selectNodes()—用一个XPath表达式查询选择节点。
selectSingleNode()—查找和XPath查询匹配的一个节点。
transformNode()—使用XSLT把一个节点转换为一个字符串。
transformNodeToObject()—使用XSLT把一个节点转换成为一个文档。
三、js访问xml节点操作的类
<script type="text/javascript">
x=xmlDoc.getElementsByTagName("title")[0];
y=x.childNodes[0];
txt=y.nodeValue;
//结果:txt = "Everyday Italian"
//获取属性值 - getAttribute()
xmlDoc=loadXMLDoc("books.xml");
txt=xmlDoc.getElementsByTagName("title")[0].getAttribute("lang");
//结果:txt = "en"
//获取属性值 - getAttributeNode()
x=xmlDoc.getElementsByTagName("title")[0].getAttributeNode("lang");
txt=x.nodeValue;
//改变文本节点得值
xmlDoc = loadXMLDoc("books.xml");
x = xmlDoc .getElementsByTagName("title")[0].childNodes[0];
x.nodeValue="Easy Cooking";
//改变属性的值
xmlDoc = loadXMLDoc("books.xml");
x = xmlDoc .getElementsByTagName("book");
x[0].setAttribute("category","food");
//删除元素节点
xmlDoc = loadXMLDoc("books.xml");
y = xmlDoc.getElementsByTagName("books")[0];
xmlDoc.documentElement.removeChild(y);
//删除自身
xmlDoc = loadXMLDoc("books.xml");
x = xmlDoc.getElementsByTagName("book")[0];
x.parentNode.removeChild(x);
//删除文本节点
xmlDoc = loadXMLDoc("books.xml");
x = xmlDoc.getElementsByTagName("title")[0];
y = x.childNodes[0];
x.removeChild(y);
//清空文本节点
xmlDoc = loadXMLDoc("books.xml");
x = xmlDoc.getElementsByTagName("title")[0];
x.nodeValue = "";
//根据名称删除属性节点
xmlDoc = loadXMLDoc("books.xml");
x = xmlDoc.getElementsByTagName("book");
x[0].removeAttribute('category');
//根据对象删除属性节点
xmlDoc = loadXMLDoc("books.xml");
x = xmlDoc.getElementsByTagName("book");
for(var i=0;i<x.length;i++){
while(x[i].attributes.length>0){
attnode=x[i].attributes[0];
old_att=x[i].removeAttributeNode(attnode);
}
}
x[0].removeAttribute(category);
</script>
//replaceChild() 方法用于替换节点。
xmlDoc = loadXMLDoc("books.xml");
x = xmlDoc.documentElement;
//create a book element, title element and a text node
newNode = xmlDoc.createElement("book");
newTitle = xmlDoc.createElement("title");
newText = xmlDoc.createTextNode("A Notebook");
//add the text node to the title node,
newTitle.appendChild(newText);
//add the title node to the book node
newNode.appendChild(newTitle);
y = xmlDoc.getElementsByTagName("book")[0];
//replace the first book node with the new node
x.replaceChild(newNode,y);
//替换文本节点中的数据
replaceData()方法用于替换文本节点中的数据。
replaceData()方法有三个参数:
offset-在何处开始替换字符。Offset值以0开始。
length-要替换多少字符。
string-要插入的字符串。
xmlDoc = loadXMLDoc("books.xml");
x = xmlDoc.getElementsByTagName("title")[0].childNodes[0];
x.replaceDate(0,8,"Easy");
用nodeValue属性来替换文本节点中的数据。
xmlDoc = loadXMLDoc("books.xml");
x = xmlDoc.getElementsByTagName("title")[0].childNodes[0];
x.nodeValue="Easy Italian";
//创建新的元素节点
createElement()方法创建新的元素节点。
xmlDoc = loadXMLDoc("books.xml");
newNode = xmlDoc.createElement("edition");
x = xmlDoc.getElementsByTagName("book")[0];
x.appendChild(newNode);
//创建新的属性节点
xmlDoc = loadXMLDoc("books.xml");
newAtt = xmlDoc.createAttribute("edition");
newAtt.nodeValue ="first";
x = xmlDoc.getElementsByTagName("title");
x[0].setAttributeNode(newAtt);
//通过setAttribute创建属性。
xmlDoc = loadXMLDoc("books.xml");
x = xmlDoc.getElementsByTagName("book");
x[0].setAttribute("edition","first");
//创建文本节点
createTextNode()方法创建新的文本节点。
xmlDoc = loadXMLDoc("books.xml");
newNode = xmlDoc.createElement("publisher");
newText = xmlDoc.createTextNode("english");
newNode.appendChild(newText);
x = xmlDoc.getElementsByTagName("book")[0];
x.appendChild(newNode);
//创建一个CDATA Section节点
xmlDoc = loadXMLDoc("books.xml");
newCDATA = xmlDoc.createCDATASection("Special offer & Book Sale");
x = xmlDoc.getElementsByTagName("book")[0];
x.appendChild(newCDATA);
//创建注释节点
xmlDoc = loadXMLDoc("books.xml");
newComment = xmlDoc.createComment("Revised March 2008");
x=xmlDoc.getElementsByTagName("book")[0];
x.appendChild(newComment);
//添加节点
xmlDoc = loadXMLDoc("books.xml");
newNode = xmlDoc.createElement("publisher");
x = xmlDoc.getElementsByTagName("book")[0];
x.appendChild(newNode);
//插入节点--insertBefore()
xmlDoc = loadXMLDoc("books.xml");
newNode = xmlDoc.createElement("book");
x = xmlDoc.documentElement;
y = xmlDoc.getElementsByTagName("book")[3];
x.insertBefore(newNode,y);
//添加新属性
xmlDoc = loadXMLDoc("books.xml");
x = xmlDoc.getElementsByTagName("book");
x[0].setAttribute("edition","first");
//向文本节点添加文本--insertData()
xmlDoc = loadXMLDoc("books.xml");
x = xmlDoc.getElementsByTagName("title")[0].childNodes[0];
x.insertData(0,"Easy");
//复制节点
xmlDoc = loadXMLDoc("books.xml");
oldNode = xmlDoc.getElementsByTagName("book")[0];
newNOde = oldNode.cloneNode(true);
xmlDoc.documentElement.appendChild(newNode);
//output all titles
y = xmlDoc.getElementsByTagName("title");
for(var i=0;i<y.length;i++){
document.write(y[i].childNodes[0].nodeValue);
document.write("<br/>");
}
- iis部署后浏览没有主界面(IIS 浏览aspx页面出现无法显示XML页的解决方法分享)
- sql查询过程解析(SQL 联合查询与XML解析实例详解)
- python爬虫书籍经典(Python利用lxml模块爬取豆瓣读书排行榜的方法与分析)
- SQL中FOR XML PATH
- linq xml 查询
- php和xml有什么关系(PHP创建XML的方法示例基于DOMDocument类及SimpleXMLElement类)
- SQL Server中如何将数据导出为XML或Json文件
- treeview绑定xml
- c#操作XML文件的通用方法
- jquery解析xml
- sqlserver如何生成xml文件(实现SQL Server 原生数据从XML生成JSON数据的实例代码)
- xml属性和子元素的选择
- php在if里添加xml代码(PHP创建XML接口示例)
- php模块使用方法(PHP操作XML中XPath的应用示例)
- ASP.NET中XML和JSON互转
- tomcatxml文件放在哪(Tomcat中修改server.xml和content.xml后自动还原问题解决)
- 泰剧《爱欲之神》Boom kitkong和Great合体杂志(泰剧爱欲之神Boomkitkong和Great合体杂志)
- 素人恋爱综艺火药味十足 男生为赢得芳心集体扯头花,真是出好戏(素人恋爱综艺火药味十足)
- 《囧妈》为何受抵制 春节七部影片撤档背后的责任与博弈(囧妈为何受抵制)
- 提醒 2019年起河南驾考要开设科目五 官方回应来了(2019年起河南驾考要开设科目五)
- 省 市书法家协会 送万福进万家 活动走进禹州美丽乡村(省市书法家协会)
- 点赞 禹州苌庄正式撤乡建镇 未来发展不可估量(禹州苌庄正式撤乡建镇)
热门推荐
- sql提交事务代码(SQL SERVER提交事务回滚机制)
- laravel模块教程(Laravel框架创建路由的方法详解)
- dedecms列表分页代码(Dedecms文章设置推荐后列表页标题自动加粗的解决方法)
- phpredis使用场景(php和redis实现秒杀活动的流程)
- vue过滤器使用思路(vue 过滤器和自定义指令的使用)
- html5页面强制刷新(移动端html5判断是否滚动到底部并且下拉加载)
- vue跨域代理怎么写(解决vue $http的get和post请求跨域问题)
- SQL SERVER中查看一个数据库的表结构及字段
- 阿里云配置宝塔(在阿里云购买云服务器并安装宝塔面板的步骤)
- html5横向滚动(解决HTML5中滚动到底部的事件问题)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9