Js读取XML文件为List结构
习惯了C#的List集合,对于Javascript没有list 极为不舒服,在一个利用Js读取XML文件的Demo中,决定自己构建List对象,将数据存入List.
第一步,Js读取XML文件知识
XML:可扩展标记语言,常用于互联网数据传输.利用JS读取XML的文章有非常多,这里不一一介绍,本文主要采用Jquery 读取Xml文件.(参考 https://www.cnblogs.com/huacw/archive/2011/03/24/1994074.html).读取文件需要注意浏览器兼容问题,利用谷歌浏览器读取文件需要设置允许访问本地文件.火狐与Edge,IE浏览器均能读取本地文件.
第二步: 分析XML结构
本文以商品结构为例,XML文件结果如下图所示.XML 根节点为CATALOG,子节点为FurnitureType(家具类型),家具类型子节点为Goods


第二步: 构建Goods对象,List对象
Goods
//产品类
function Goods(){ this.type = type;
this.product = product;
this.brand = brand;
this.price=price;
this.productDetails=productDetails;
this.materies=materies;
this.care=care;
this.pictures=pictures; } function type(type){
return type;
}
function product(product)
{
return product;
}
function brand(brand){
return brand;
}
function price(price)
{
return price;
}
function productDetails(details){
return details;
}
function materies(meteriesArray){
return meteriesArray;
}
function care(care){
return care;
}
function pictures(pictureArray){
return pictureArray;
}
List对象
/*
* List 大小可变数组
*/
function List() {
this.List = new Array();
}; /**
* 将指定的元素添加到此列表的尾部。
* @param object 指定的元素
*/
List.prototype.add = function(object) {
//this.List[this.List.length] = object;
this.List.push(object);
}; /**
* 将List添加到此列表的尾部。
* @param Listgoods 一个列表
*/
List.prototype.addAll = function(Listgoods) {
this.List = this.List.concat(Listgoods.List);
}; /**
* 返回此列表中指定位置上的元素。
* @param index 指定位置
* @return 此位置的元素
*/
List.prototype.get = function(index) {
return this.List[index];
}; /**
* 获取元素在数组中的坐标,不存在则返回-1
* @return true or false
*/
List.prototype.getdataIndex = function(object) {
var i = 0;
for(; i < this.List.length; i++) {
if( this.List[i] === object) {
return i;
}
}
return -1;
}; /**
* 移除此列表中指定位置上的元素。
* @param index 指定位置
* @return 此位置的元素
*/
List.prototype.removeIndex = function(index) {
var object = this.List[index];
this.List.splice(index, 1);
return object;
}; /**
* 移除此列表中指定元素。
* @param object 指定元素
* @return 此位置的元素
*/
List.prototype.remove = function(object) {
var i = this.getdataIndex(object); if(i==-1) {
return null;
} else {
return this.removeIndex(i);
}
}; /**
* 移除此列表中的所有元素。
*/
List.prototype.clear = function() {
this.List.splice(0, this.List.length);
}; /**
* 返回此列表中的元素数。
* @return 元素数量
*/
List.prototype.size = function() {
return this.List.length;
}; /**
* 返回列表中指定的 start(包括)和 end(不包括)之间列表。
* @param start 开始位置
* @param end 结束位置
* @return 新的列表
*/
List.prototype.subList = function(start, end) {
var List = new List();
List.List = this.List.slice(start, end);
return List;
}; /**
* 如果列表不包含元素,则返回 true。
* @return true or false
*/
List.prototype.isEmpty = function() {
return this.List.length == 0;
};
/**
* 根据价格对商品列表进行排序。
* @return 排序后列表
*/
List.prototype.SortByPrice=function(){
var length= this.List.length;
for(var j=0;j< length-1;j++){
//两两比较,如果前一个比后一个大,则交换位置。
for(var i=0;i<length-1-j;i++){
if(this.List[i].price>this.List[i+1].price){
var temp = this.List[i];
this.List[i] = this.List[i+1];
this.List[i+1] = temp;
}
}
} }
/**
*
* @param type 数据类型
* @return 排序后列表
*/
List.prototype.GetDataByType=function(type){
var NewList = new List();
for(var i=0;i<this.List.length;i++){
var object=this.List[i] ;
if(object.type==type){
NewList.add(object)
}
}
return NewList;
} /**
*
* @param type 数据类型
* @return 数据类型的 品牌列表
*/
List.prototype.GetBrandsByType=function(type){
var dataList =this.GetDataByType(type);
var brandList=new List();
for(var i=0;i<dataList.List.length;i++){
var brand=dataList.List[i].brand;
if(brandList.getdataIndex(brand)==-1){
brandList.add(brand);
}
}
return brandList;
}
第三步;读取文件
本文利用Jquery读取XML文件,需导入Jquery.读取部分代码:
var AllGoodsList = new List();//所有数据 //读取文件 获取数据
function GetXml() {
$.ajax({
url: 'file/data.xml',
dataType: 'xml',
success: function (data) {
//获取xml数据
isLoadDataOK= GetData(data); }
}); }
//读取xml数据存入list集合
function GetData(data) {
var nowGoodsType;
$(data).find("Type").each(function (i, Type) {
var type=$(this).attr("name");
if(type=="Categories"){
$(Type).find("GoodsType").each(function (i, GoodsType) {
nowGoodsType = $(this).attr("name");
$(GoodsType).find("Goods").each(function (j) { var base = $(this).children("Base");
var product = base.children("Product").text();
var brand = base.children("Brand").text();
var price = base.children("Price").text();
var productDetails = $(this).children("ProductDetails").text();
var material = new Array();
var materials = $(this).children("Material");
var materialnodes = materials.children("item");
for (var i = 0; i < materialnodes.length; i++) {
var item = materialnodes[i];
var itemvalue = item.textContent;
material.push(itemvalue)
}
var care = $(this).children("Care").text();
var pictures = new Array();
var pictures = $(this).children("Picture");
var picturenodes = pictures.children("item")
for (var i = 0; i < picturenodes.length; i++) {
var item = picturenodes[i];
var itemvalue = item.textContent;
pictures.push(itemvalue)
}
var goods = new Goods();
goods.type = nowGoodsType;
goods.product = product;
goods.brand = brand;
goods.price = price;
goods.productDetails = productDetails;
goods.materies = material;
goods.care = care;
goods.pictures = pictures;
var p1=price.replace("A","");
var p2=p1.replace("U","");
var p3=p2.replace("$","");
goods.thePrice=p3;
AllGoodsList.add(goods); })
}) } }
)
}
第四步 启动测试:
启动火狐浏览器,读取文件后,调试查看数据.结果如下.表明数据已经完全读取成功.

Js读取XML文件为List结构的更多相关文章
- IE下JS读取xml文件示例代码
JS读取xml文件具体步骤为:创建DOM对象.加载xml文件(仅适用于IE)附示例代码,感兴趣的朋友可以参考下,希望对大家有所帮助使用javascript脚本读取xml文件,这里暂只考虑IE浏览器st ...
- jQuery、JS读取xml文件里的内容(JS先通过document.implementation.createDocument方法将xml转换成document对象,jQuery将读取到的xml转成table)
xml文件:test.xml <?xml version="1.0"?> <note> <to>George</to> <fr ...
- js 读取xml文件
读取xml文件 [原创 2007-6-20 17:35:37] 字号:大 中 小 js中读取xml文件,简单的例子: <html><head><script> ...
- JS读取XML文件数据并以table显示数据(兼容IE火狐)
先看xml文件: <?xml version="1.0" standalone="yes"?> <student> <stuinf ...
- js读取xml文件
假设我们现在要读取下面的 info.xml 文件 <?xml version="1.0" encoding="gb2312"?> <root& ...
- [HTML]js读取XML文件并解析
xml文件:test.xml <?xml version="1.0"?> <note> <to>George</to> <fr ...
- 【JavaScript】JS读取XML文件并进行搜索
需求效果 点击链接.当前页面载入xml文件并展示相应内容 通过搜索框.搜索xml文件内节点数据.展示包括内容的节点数据 功能实现 Demo终于实现效果 http://loadxmldemo.coder ...
- js操作XML文件兼容IE与FireFox
最近项目中用到了xml,需求是用户安装产品时先把一系列的数据保存到xml文件中,当执行到最后一步时才写入数据库,这样最大限度的减少了数据库的访问,于是不得不纠结在各浏览器的兼容性的问题(悲哀啊.... ...
- 浅谈JS中的!=、== 、!==、===的用法和区别 JS中Null与Undefined的区别 读取XML文件 获取路径的方式 C#中Cookie,Session,Application的用法与区别? c#反射 抽象工厂
浅谈JS中的!=.== .!==.===的用法和区别 var num = 1; var str = '1'; var test = 1; test == num //tr ...
随机推荐
- 对Controller的单元测试
在ASP.NET MVC项目的Controller中存在逻辑代码,也需要单元测试.查阅到的资料上,有说ASP.NET MVC框架在设计时便考虑到了满足可测试性,所以相对aspx.Winform来说针对 ...
- vm virtualBox下 centos7 Linux系统 与本地 window 系统 网络连接 配置
由于要模拟生产环境开发,所以要在自己的电脑上安装虚拟机,这里做一下记录. centos与本机网络连接 1. 环境 虚拟机 VirtualBox-5.2.0-118431-Win Linux镜像 Cen ...
- C# 获得目录下所有文件或指定文件类型文件(包含所有子文件夹)
public partial class FileGet { /// <summary> /// 私有变量 /// </summary> private static List ...
- TFS命令行操作
前言 本文主要介绍如何通过TFS(Team Foundation Server)命令行强制解锁(UnDo)项目成员对项目文件的占用. 正文 在多人同时开发项目的时候,如果遇到项目组成员独占签出文件后未 ...
- 给Jqgrid添加横向滚动条,实现点击行数据,触发事件。
function reloadNoKitScheduleGridData() { $("#noKittingScheduleList").jqGrid({ url: ". ...
- 针对于多个inner join或者left join多条件查询的时候,各个inner join 的指向问题
转自https://blog.csdn.net/ck457897564/article/details/52487684 先看一段代码吧: <span style="font-size ...
- python selenium模拟登录163邮箱和QQ空间
最近在看python网络爬虫,于是我想自己写一个邮箱和QQ空间的自动登录的小程序, 下面以登录163邮箱和QQ空间和为例: 了解到在Web应用中经常会遇到frame/iframe 表单嵌套页面的应用, ...
- net.exe use命令的使用
net.exe use 查看当前的连接 net.exe use * /del /y 断开所有连接 net.exe use \\server\share "password" /us ...
- linux正则表达式(基础正则表达式+扩展正则表达式)
正则表达式应用非常广泛,例如:php,Python,java等,但在linux中最常用的正则表达式的命令就是grep(egrep),sed,awk等,换句话 说linux三剑客要想能工作的更高效,就一 ...
- 一些安卓模拟器的IP问题和getOutputStream();关于connect();的函数异常的问题
ip问题 1.不能使用local host 和127.0.0.1作为本地服务器的地址,而网上无论10.0.0.2还是10.0.2.2的8080端口都无法访问.真正的地址应该在CMD 键入ipconfi ...