JS解析xml文件为字符串

今天的实战案例呢是关于前端解析xml数据

日常为了服务器的尽量把很多任务交个前端处理这样避免的了服务器的CPU使用以及服务器压力和流量所以呢这次我们在解析xml的时候这个任务选放到了前端

xml转字符串

$(function () {
        $.get("https://localhost:44396/house.xml", function (data) {
            $(data).find('address').find('city').each(function (index, ele) {
                var titles = $(ele).find('price').text();
                var links = $(ele).find('type').text();
                $("#anotherElement").append('<li><a href="' + links + '">' + titles + '</a></li>');

            })

        });

字符串转xml

//xml字符串

var str = "<DongFang><Company><cNname>cNname1</cNname><cIP>cIP1</cIP></Company><Company><cNname>cNname2</cNname><cIP>cIP2</cIP></Company><Company><cNname>cNname3</cNname><cIP>cIP3</cIP></Company><Company><cNname>cNname4</cNname><cIP>cIP4</cIP></Company><Company><cNname>cNname5</cNname><cIP>cIP5</cIP></Company><Company><cNname>cNname6</cNname><cIP>cIP6</cIP></Company></DongFang>"

      var arr = [];

      function getXmlNode(str){

      //创建文档对象

      var parser=new DOMParser();

      var xmlDoc=parser.parseFromString(str,"text/xml");

      //提取数据---循环每一个Company  --或者提取某一个节点比如:cNname

      var countrys = xmlDoc.getElementsByTagName('cNname')

      for (var i = 0; i < countrys.length; i++) {

        //textContent表示将指定节点下面的每一个元素提取出来

        console.log(countrys[i]);

      arr.push(countrys[i].textContent);

      };

      console.log(arr);

      return arr;

      }

      //将数据转成json格式

      function infoToJson(str){

      var s = getXmlNode(str);

      console.log(s);

      }

      infoToJson(str);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
可以使用JavaScript内置的XML解析器DOMParser来解析XML文件XML格式字符串。下面是一个示例代码: ```javascript // 定义一个XML格式的字符串 var xmlString = '<root><person><name>张三</name><age>18</age></person></root>'; // 创建一个DOMParser对象 var parser = new DOMParser(); // 解析XML字符串 var xmlDoc = parser.parseFromString(xmlString, 'text/xml'); // 获取XML文档中的元素 var name = xmlDoc.getElementsByTagName('name')[0].childNodes[0].nodeValue; var age = xmlDoc.getElementsByTagName('age')[0].childNodes[0].nodeValue; // 打印结果 console.log('name:', name); console.log('age:', age); ``` 在上面的代码中,我们首先定义了一个XML格式的字符串,然后创建了一个DOMParser对象,使用parseFromString方法来解析XML字符串,最后从解析后的文档中获取元素并打印结果。 如果要解析XML文件,可以使用XMLHttpRequest对象来获取XML文件内容,然后再使用DOMParser解析。具体代码请参考下面的示例: ```javascript // 创建XMLHttpRequest对象 var xhr = new XMLHttpRequest(); // 发送GET请求获取XML文件内容 xhr.open('GET', 'example.xml', true); xhr.send(); // 监听XML文件加载完成事件 xhr.onreadystatechange = function() { if (xhr.readyState == 4 && xhr.status == 200) { // 获取XML文件内容 var xmlString = xhr.responseText; // 创建DOMParser对象 var parser = new DOMParser(); // 解析XML字符串 var xmlDoc = parser.parseFromString(xmlString, 'text/xml'); // 获取XML文档中的元素 var name = xmlDoc.getElementsByTagName('name')[0].childNodes[0].nodeValue; var age = xmlDoc.getElementsByTagName('age')[0].childNodes[0].nodeValue; // 打印结果 console.log('name:', name); console.log('age:', age); } }; ``` 在上面的代码中,我们创建了一个XMLHttpRequest对象,使用GET请求获取XML文件内容,然后使用DOMParser解析XML字符串,最后从解析后的文档中获取元素并打印结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

沪上百卉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值