模板维护-模板解析

        关于模板的解析,主要是关于主模板的解析。

        首先来说一下业务逻辑,首先点击树的节点,将树的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和下拉列表进行数据绑定,就可以赋值了。


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



你可能感兴趣的:(模板维护-模板解析)