您的位置:首页 > 运维架构

模板维护-模板解析

2015-08-01 11:09 330 查看
关于模板的解析,主要是关于主模板的解析。

首先来说一下业务逻辑,首先点击树的节点,将树的code付给物资编码,然后通过物资编码去查询主模板(包括主模板ID和主模板信息)和子模板(不带{}的信息);

如果有{}形式的信息,我们把主模板ID和主模板信息付给String参数,传到前台。在前台,首先判断传过来的String参数是否为空,如果为空则说明没有主模板,否则加载子模板信息。



解析主模板:



第一步:


从上面的逻辑中获取到主模板信息是 {:内燃机车,0;电力机车,1;客车,2;货车,3;动车组,4;待报废,5;其他淘汰物资,9;}这种形式的数据。

第二步:




我们对它进行拆分。

定义一个datatable,然后为它分配两个字段:一个ID,一个Name。




第三步:



切割字符串,先把最前面的两个字符 {: 删除 方法如下:Substring(2, Smatlcate.Length - 2)

字符串则变成了 内燃机车,0;电力机车,1;客车,2;货车,3;动车组,4;待报废,5;其他淘汰物资,9;}

然后我们将最后的 } 去掉 方法如下:.Split('}')[0].Trim()



字符串则变成了 内燃机车,0;电力机车,1;客车,2;货车,3;动车组,4;待报废,5;其他淘汰物资,9;



我们将最后的分号;去掉 方法如下:TrimEnd(';')



字符串则变成了 内燃机车,0;电力机车,1;客车,2;货车,3;动车组,4;待报废,5;其他淘汰物资,9

第三步:




这样我们就能进行数组转换了:string[] strArr = Smatlcate.Split(';') 这是以分号位分隔符进行的数组转换

第四步:

最后我们就可以进行为原先定义的datatable(包含两个地段)循环赋值了,方法如下:

DataRow dr = dt_ChildTemplets.NewRow();

dr["ID"] = strArr[i].Split(',')[1].Trim();

dr["NAME"] = "系列:" + strArr[i].Split(',')[0].Trim() + "," + strArr[i].Split(',')[1].Trim();

最后我们就成功的将数组的信息传到datatable中去了。




dt和下拉列表进行数据绑定,就可以赋值了。





后续还会有子模板解析和模板测试的博文。



内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: