习惯了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结构的更多相关文章

  1. IE下JS读取xml文件示例代码

    JS读取xml文件具体步骤为:创建DOM对象.加载xml文件(仅适用于IE)附示例代码,感兴趣的朋友可以参考下,希望对大家有所帮助使用javascript脚本读取xml文件,这里暂只考虑IE浏览器st ...

  2. jQuery、JS读取xml文件里的内容(JS先通过document.implementation.createDocument方法将xml转换成document对象,jQuery将读取到的xml转成table)

    xml文件:test.xml <?xml version="1.0"?> <note> <to>George</to> <fr ...

  3. js 读取xml文件

    读取xml文件 [原创 2007-6-20 17:35:37]     字号:大 中 小 js中读取xml文件,简单的例子: <html><head><script> ...

  4. JS读取XML文件数据并以table显示数据(兼容IE火狐)

    先看xml文件: <?xml version="1.0" standalone="yes"?> <student> <stuinf ...

  5. js读取xml文件

    假设我们现在要读取下面的 info.xml 文件 <?xml version="1.0" encoding="gb2312"?> <root& ...

  6. [HTML]js读取XML文件并解析

    xml文件:test.xml <?xml version="1.0"?> <note> <to>George</to> <fr ...

  7. 【JavaScript】JS读取XML文件并进行搜索

    需求效果 点击链接.当前页面载入xml文件并展示相应内容 通过搜索框.搜索xml文件内节点数据.展示包括内容的节点数据 功能实现 Demo终于实现效果 http://loadxmldemo.coder ...

  8. js操作XML文件兼容IE与FireFox

    最近项目中用到了xml,需求是用户安装产品时先把一系列的数据保存到xml文件中,当执行到最后一步时才写入数据库,这样最大限度的减少了数据库的访问,于是不得不纠结在各浏览器的兼容性的问题(悲哀啊.... ...

  9. 浅谈JS中的!=、== 、!==、===的用法和区别 JS中Null与Undefined的区别 读取XML文件 获取路径的方式 C#中Cookie,Session,Application的用法与区别? c#反射 抽象工厂

    浅谈JS中的!=.== .!==.===的用法和区别   var num = 1;     var str = '1';     var test = 1;     test == num  //tr ...

随机推荐

  1. MVC与单元测试实践之健身网站(一)-项目概述

    前不久刚刚通过租房网站的开发学习了MVC,并随后学习了单元测试相关的基础,现在开始健身网站的开发,该项目将结合MVC与单元测试,在开发实践过程中,趁热打铁,巩固并运用之前的内容. 一 健身网站功能描述 ...

  2. ionic左滑删除

    <html ng-app="ionicApp"> <head> <meta charset="utf-8"> <met ...

  3. url override and HttpSession implements session for form

    url 重写结合HttpSession实现会话管理之 form 提交 package com.test; import javax.servlet.ServletException; import j ...

  4. Expo大作战(二)--expo的生命周期,expo社区交流方式,expo学习必备资源,开发使用expo时关注的一些问题

    简要:本系列文章讲会对expo进行全面的介绍,本人从2017年6月份接触expo以来,对expo的研究断断续续,一路走来将近10个月,废话不多说,接下来你看到内容,讲全部来与官网 我猜去全部机翻+个人 ...

  5. RHEL7系统管理常用工具

    RHEL7提供大量系统管理工具,简要记录一下各工具的作用,后续再详细说明用法. 工具 描述 /proc linux的内存镜像目录./proc/sys目录下的文件能被临时修改,从而改变linux内核参数 ...

  6. 从MySQL slave system lock延迟说开去

    本文主要分析 sql thread中system lock出现的原因,但是笔者并明没有系统的学习过master-slave的代码,这也是2018年的一个目标,2018年我都排满了,悲剧.所以如果有错误 ...

  7. 一个U盘黑掉你:TEENSY实战(test)

    挖掘过程一: 自从上一次投稿,已经好久好久没写文章了.今天就着吃饭的时间,写篇文章,记录下自己学习xss这么久的心得.在我看来.Xss就是javascript注入,你可以在js语法规定的范畴内做任何事 ...

  8. Netty入门(五)ChanneHandler

    本节主要讨论了 Netty 的数据处理组件 ChannelHandler. 一.Channel 生命周期 Channel 有个简单但强大的状态模型,下面是 Channel 的四个状态: Channel ...

  9. Kafka学习之路 (五)Kafka在zookeeper中的存储

    一.Kafka在zookeeper中存储结构图 二.分析 2.1 topic注册信息 /brokers/topics/[topic] : 存储某个topic的partitions所有分配信息 [zk: ...

  10. win10下nvidia控制面板看不到

    64位win10,nvidia控制面板看不到,控制面板里没有,服务里也没有nvidia相关服务,但驱动已经安装了. 解决办法: 1.下载GeForce Experience并安装 . 2.通过GeFo ...