在前面 CodeSmith 使用教程(6): 基本語法-聲明和使用屬性介紹了 CodeSmith 中使用屬性的基本方法,模板中的屬性是通過 Property 指令來定義。
CodeSmith 也支持使用 XML 文檔來定義屬性,可以把一些配置屬性定義到 XML 文件中,定義 XML 的屬性是使用 XmlProperty 來定義:
<%@ XmlProperty Name="PurchaseOrder"
Schema="PO.xsd"
Optional="False"
Category="Data"
Description="Purchase Order to generate packing list for." %>
XmlProperty 指令可以有多個參數(shù),除 Name 為必須的外,其它的參考都是可選的。
屬性參數(shù)的介紹:
本例使用 CodeSmith 自帶的一個例子,使用 PurchaseOrder.xsd ,XML 的定義如下:
<?xml version="1.0" encoding="utf-8"?>
<xs:schema targetNamespace="http://www.codesmithtools.com/purchaseorder"
elementFormDefault="qualified"
xmlns="http://www.codesmithtools.com/purchaseorder"
xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xs:element name="PurchaseOrder">
<xs:complexType>
<xs:sequence>
<xs:element name="OrderDate" type="xs:string" minOccurs="1" maxOccurs="1" />
<xs:element name="SubTotal" type="xs:string" minOccurs="1" maxOccurs="1" />
<xs:element name="ShipCost" type="xs:string" minOccurs="0" maxOccurs="1" />
<xs:element name="TotalCost" type="xs:string" minOccurs="1" maxOccurs="1" />
<xs:element name="ShipTo" minOccurs="0" maxOccurs="1">
<xs:complexType>
<xs:sequence>
<xs:element name="Line1" type="xs:string" minOccurs="0" maxOccurs="1" />
<xs:element name="City" type="xs:string" minOccurs="0" maxOccurs="1" />
<xs:element name="State" type="xs:string" minOccurs="0" maxOccurs="1" />
<xs:element name="Zip" type="xs:string" minOccurs="0" maxOccurs="1" />
</xs:sequence>
<xs:attribute name="Name" type="xs:string" />
</xs:complexType>
</xs:element>
<xs:element name="Items" minOccurs="0" maxOccurs="1">
<xs:complexType>
<xs:sequence>
<xs:element name="OrderedItem" minOccurs="0" maxOccurs="unbounded">
<xs:complexType>
<xs:sequence>
<xs:element name="ItemName" type="xs:string" minOccurs="1" maxOccurs="1" />
<xs:element name="Description" type="xs:string" minOccurs="0" maxOccurs="1" />
<xs:element name="UnitPrice" type="xs:string" minOccurs="1" maxOccurs="1" />
<xs:element name="Quantity" type="xs:string" minOccurs="1" maxOccurs="1" />
<xs:element name="LineTotal" type="xs:string" minOccurs="1" maxOccurs="1" />
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:schema>
與這個 XML Schema 配合使用的用來存放 XML 屬性的 XML 文件為 SamplePurchaseOrder.xml ,其定義如下:
<?xml version="1.0"?>
<PurchaseOrder xmlns="http://www.codesmithtools.com/purchaseorder">
<ShipTo Name="Eric J. Smith">
<Line1>123 Test Dr.</Line1>
<City>Dallas</City>
<State>TX</State>
<Zip>75075</Zip>
</ShipTo>
<OrderDate>05-01-2003</OrderDate>
<Items>
<OrderedItem>
<ItemName>Item #1</ItemName>
<Description>Item #1 Description</Description>
<UnitPrice>5.45</UnitPrice>
<Quantity>3</Quantity>
<LineTotal>16.35</LineTotal>
</OrderedItem>
<OrderedItem>
<ItemName>Item #2</ItemName>
<Description>Item #2 Description</Description>
<UnitPrice>12.75</UnitPrice>
<Quantity>8</Quantity>
<LineTotal>102.00</LineTotal>
</OrderedItem>
</Items>
<SubTotal>45.23</SubTotal>
<ShipCost>5.23</ShipCost>
<TotalCost>50.46</TotalCost>
</PurchaseOrder>
定義一個簡單的模板,把 SamplePurchaseOrder.xml 中的內容重新輸出,可以在代碼模板中定義一個XMLProperty ,其 Schema 指定為 PurchaseOrder.xsd
<%--
This template demonstates using the XmlProperty directive
--%>
<%@ CodeTemplate Language="C#" TargetLanguage="Text"
Description="Demonstrates using the Xml serializer." %>
<%@ XmlProperty
Name="MyPurchaseOrder"
Schema="PurchaseOrder.xsd"
Default="SamplePurchaseOrder.xml" %>
This file generated by CodeSmith on <%= DateTime.Now.ToLongDateString() %>
PurchaseOrder:
Address:
Name: <%= MyPurchaseOrder.ShipTo.Name %>
Line1: <%= MyPurchaseOrder.ShipTo.Line1 %>
City: <%= MyPurchaseOrder.ShipTo.City %>
State: <%= MyPurchaseOrder.ShipTo.State %>
Zip: <%= MyPurchaseOrder.ShipTo.Zip %>
OrderDate: <%= MyPurchaseOrder.OrderDate %>
Items:
<% for (int i = 0; i < MyPurchaseOrder.Items.Count; i++) { %>
<%= i %>:
ItemName: <%= MyPurchaseOrder.Items[i].ItemName %>
Description: <%= MyPurchaseOrder.Items[i].Description %>
UnitPrice: <%= MyPurchaseOrder.Items[i].UnitPrice %>
Quantity: <%= MyPurchaseOrder.Items[i].Quantity %>
LineTotal: <%= MyPurchaseOrder.Items[i].LineTotal %>
<% } %>
SubTotal: <%= MyPurchaseOrder.SubTotal %>
ShipCost: <%= MyPurchaseOrder.ShipCost %>
TotalCost: <%= MyPurchaseOrder.TotalCost %>
模板中定義的 XML 屬性名為 MyPurchaseOrder 對應的 Schema 為 PurchaseOrder.xsd ,因此在代碼模板可以通過 MyPurchaseOrder.ShipTo.Name 的格式來直接引用 XML Schema 中定義的元素,CoddSmith 也支持 IntelliSense。
運行該模板,首先需要為 MyPurchaseOrder 選擇合適的 XML 文件:
如果選擇的文件不符合指定的 XML Schema,CodeSmith 不允許選擇該文件,本例使用預先定義的SamplePurchaseOrder.xml ,生成的文件如下:
This file generated by CodeSmith on Saturday, 12 January 2013
PurchaseOrder:
Address:
Name: Eric J. Smith
Line1: 123 Test Dr.
City: Dallas
State: TX
Zip: 75075
OrderDate: 05-01-2003
Items:
0:
ItemName: Item #1
Description: Item #1 Description
UnitPrice: 5.45
Quantity: 3
LineTotal: 16.35
1:
ItemName: Item #2
Description: Item #2 Description
UnitPrice: 12.75
Quantity: 8
LineTotal: 102.00
SubTotal: 45.23
ShipCost: 5.23
TotalCost: 50.46
本例下載
更多建議: