`
zendj
  • 浏览: 121330 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
文章分类
社区版块
存档分类
最新评论

CodeSmith的模版中的语法

阅读更多
本篇将介绍CodeSmith的模版中的语法。
标签
标签一般出现在模板的头部,被用做设置许多不同的属性。
代码模板的声明(CodeTemplate Directive
这个是模板中唯一必须的声明,包含一些模板特殊的属性,包含模板使用的语言、生成的语言和一些对于模板的描述。
例:
<%@CodeTemplateLanguage="C#"TargetLanguage="C#"Description="Generatesaclass."%>
参数的介绍:
Language
:在开发编写模板时使用的语言,例如C#VB.NETJscript等。
TargetLanguage
:只是对模板代码的一个分类,不会影响生成的代码语言。是模板的一个属性,说明模板要基于那种语言生成相应的代码。例如你可以用CodeSmith从任何一种语言生成C#代码。
Description
:对于模板的一些说明信息,在CodeSmith Explorer中选中该模板时会显示这里的信息。
Inherits
:所有CodeSmith模板默认继承自CodeSmith.Engine.CodeTemplate,这个类提供模板使用的一些基本功能,像ASP.NET页面的Page类,这些被继承的类的属性可以被修改,但是这些新的类也必须继承CodeSmith.Engine.CodeTemplateCodeSmith也同样可以找到这个类,当然你要引入一个组件包含这个类。
Src
:在某些方面Src和继承Inherits比较相似,它们都允许你从其他的类包含一些功能进模板。这两个属性的区别是,Src可以让类与你的模板被动态编译,而Inherits仅允许你提供一个已经编译好的类或组件。
Debug
:可以确定是否在模板中可以包含调试符号。如果将这个属性设置为True,则可以使用System.Diagnostics.Debugger.Break()方法来设置断点。
LinePragmas
:设置为True,模板的错误将被指向到模板的源代码。设置为False,模板的错误将被指向到编译的源代码。

属性的声明(Property Directive
属性被用做在模板运行时声明一个使用的参数,例:
<%@PropertyName="ClassName"Type="String"Default="Class1"Category="Context"Description="Thenameoftheclasstogenerate"Optional="true"%>

属性参数的介绍:

Name:模版使用的参数的名称。
Type
:参数类型可以是任何.NET有效的数据类型,例如简单的String类型或者是CodeSmithSchemaExplorer.DatabaseSchema类型。注意,类型必须是基类库的类型,例如用String或者Int32代替stringint
Default
:设置默认值。
Category
:用来说明这个属性在CodeSmith Explorer的属性面板中显示成什么类型,例如下拉选择、直接输入等。
Description
:在属性面板中对于这个属性的描述。
Optional
:设置这个属性是否是必须的,设置为True表明这个参数值可有可无,设置为False则这个参数必须有值。
Editor
:表明在属性面板中输入这个属性的值时使用何种GUI(图形界面编辑器)编辑器。
EditorBase
:编辑器使用的基本类型,如果没有被说明,UITypeEditor为默认编辑器。
Serializer
:这块我的水平不太会犯疑:)The serializer parameter specifies the IPropertySerializer type to use when serializing the properties values. This is equivalent to using a [PropertySerializerAttribute].

XML属性声明(XmlProperty Directive
例:
代码标签
<% %>
标签
可以放置任意数量的代码在其中,但并不能直接输出到模版中。

<%foreach(ColumnSchemacolumninSourceTable.Columns){%>
<%=column.Name%>
<%}%>
<%= %>标签

在模版中输出一个字符串。上例中的<%=column.Name%>

脚本标签

在这个标签中可以包含一段代码,但是他不直接影响输出的模版。可以放置一些比较有帮助的方法在其中,然后在模版的各个地方可以调用它。在脚本标签中必须包含这个参数runat=”template”,否则他会被处理成普通文本。

例:

1<scriptrunat="template">
2privatestringGetColumnName(ColumnSchemacs)
3{
4returncs.Name;
5}
6 </script>
7
8 <%foreach(ColumnSchemacsinSourceTable.Columns){%>
9 <%=GetColumnName(cs)%>
10<%}%>

使用标签可以大量减少代码,并使模版更加的易读和一管理。

Include标签

ASP.NET一样,可以在模版中包含一些文本文件,但同ASP.NET一样它也不是总能达到你的目标。

例:

<!--#includefile="myfile.inc"-->

有时在多个模版中引用一个组件中的功能,调用其中的方法,这时我们引用组件。但有些情况下,适用Include标签可以得到更好的效果。

Comment标签

注释标签,在前边已经做过介绍。

例:

<%--Thisisacomment--%>
<%@XmlPropertyName="EntityMap"Schema="EntityMap.xsd"Optional="False"Category="Context"Description="EntityMapXMLfiletobasetheoutputon."%>

XML属性的参数:
Name
:名称。
Schema
:这个参数用来指定一个XSD文件,创建一个强类型对象模型。如果这个计划被指定,编译器会尝试分析这个XSD文件并为这个计划生成一个强类型对象模型,这样可以在模版中使用强类型和智能与XML协同工作。如果这个计划没有被设定,这个参数将为XmlDocument类型并且将使用XML DOM去导航到一个XML内容并生成代码。
Category
:在CodeSmith属性面板中的类别。
Description
:描述。
Optional
:这个参数是否是必须的,如果设置为True,则参数不是必须的,反之False则为必须的。在设置为False时,如果用户没有提供参数则CodeSmith不能继续运行。

注册的声明(Register Directive
这个属性通常被用作引入另一个模版文件并与当前的模版文件同时被编译。这是一种使用子模版的交互方法。
例:

<%@RegisterName="MySubTemplate"Template="MySubTemplate.cst"MergeProperties="True"ExcludeProperties="SomeExcludedPropertyName,SomeProperties*"%>

模版一旦被注册,就可以建立一个模版的实例,然后象这样设置它的属性:

1<scriptrunat="template">
2publicvoidOutputSubTemplate()
3{
4MySubTemplatemySubTemplate=newMySubTemplate();
5
6//setanindividualpropertiesvalue.
7mySubTemplate.SomeExcludedPropertyName= "SomeValue";
8
9//copyallpropertieswithmatchingnameandtypetothesubtemplateinstance.
10this.CopyPropertiesTo(mySubTemplate);
11
12//renderthetemplatetothecurrenttemplatesResponseobject.
13mySubTemplate.Render(this.Response);
14
15//renderthetemplatetoafile.
16mySubTemplate.RenderToFile("C:\SomeFile.txt");
17}
18</script>
注册的参数:
Name
:代表被引入的模版的名称。它可以被用作创建一个模版的实例。
Template
:被引入模版文件的相对路径,它可以与当前的模版一起被动态的编译。
MergeProperties
:设置成True时,所有被引用的面板的属性将被动态的添加到当前模版中。
ExcludePorperties
:当使用MergeProperties时,你可能不需要某些属性被添加到当前模版中。将不需要的属性以逗号分隔放在这里,*号可以被用作通配符使用。

组件的声明(Assembly Directive
用作在模版中引用一个外部部组件,或者包含一个编译好的源文件。
例:
<%@AssemblyName="SchemaExplorer"%>
<%@AssemblySrc="MySourceFile.cs"%>
CodeSmith自动加载一些不同的组件:System, System.Diagnostics, System.ComponentModel, Microsoft.VisualBasic, CodeSmith.Engine

组件的参数:
Name
:需要引用组件的名称,组建必须存在于Global Assembly Cache,与CodeSmith在同一路径下或与模版文件在同一路径下。
Src
:要包含文件的相对路径。

引入的声明(Import Directive
在模版中引入一个命名空间,这个与VB.NET中的ImportsC#中的using相同。
例:
<%@ImportNamespace="SchemaExplorer"%>
引入的参数:
NameSpace
:被引入的命名空间的名字。记住同时必须要加载包含这个命名空间的相应组件,除非这个组件是被默认加载的。
分享到:
评论

相关推荐

    MySql数据库CodeSmith模板

    CodeSmith支持使用C#语法作为模板语言,使得模板的编写更为直观和强大。你可以利用它提供的各种内置函数和变量,如数据库表信息、字段信息等,来动态生成代码。 总的来说,这个"MySql数据库CodeSmith模板"是一个...

    简单的CodeSmith模板

    1. **模板语法**:CodeSmith的模板语言包含控制流语句(如if/else、for循环)、函数调用、条件表达式以及对数据源的访问。例如,`&lt;#foreach&gt;`用于遍历集合,`&lt;#if&gt;`用于条件判断,`&lt;#=Property#&gt;`用于输出属性值。 ...

    CodeSmith模板集合C#版

    CodeSmith是一款强大的代码生成工具,尤其在C#开发环境中,它极大地提高了开发效率。这个"CodeSmith模板集合C#版"包含了一系列预设...在使用前,开发者需要熟悉CodeSmith的工作原理和模板语法,以便更好地利用其优势。

    Java 代码生成器CodeSmith是一个好工具

    CodeSmith 是一种基于模板的代码生成工具,它使用类似于 ASP.NET 的语法来生成任意类型的代码或文本。与其他许多代码生成工具不同,CodeSmith 不要求您订阅特定的应用程序设计或体系结构。使用 CodeSmith,可以生成...

    CodeSmith三层架构模版

    CodeSmith是一款强大的代码生成工具,它能够帮助开发者根据预定义的模板快速生成各种类型的源代码,从而极大...在实际应用中,开发者需要熟悉CodeSmith的模板语法和三层架构的设计原则,以便更好地利用这个模板生成器。

    CodeSmith模板-V9.0版

    除了这些基础模板,CodeSmith还支持自定义模板,开发者可以通过学习和理解模板语法,创建适合自己项目需求的模板。这使得CodeSmith不仅仅是一个代码生成器,更是一个强大的代码自动化平台。 在实际开发中,使用...

    CodeSmith模版

    - **模板语法**:模板文件通常扩展名为`.cshtml`,包含C#代码和HTML(或其他语言)混合。`&lt;# #&gt;`用于包围C#代码块,`&lt;#= #&gt;`用于输出表达式结果。 - **循环与条件语句**:模板支持`foreach`、`if`等控制流语句,...

    CodeSmith企业版5.22+中文详细注释三层+抽象工厂模板+许可文件+中文件详细教程.part3

    CodeSmith 是一种基于模板的代码生成工具,它使用类似于 ASP.NET 的语法来生成任意类型的代码或文本。与其他许多代码生成工具不同,CodeSmith 不要求您订阅特定的应用程序设计或体系结构。使用 CodeSmith,可以生成...

    IBatis codesmith模板

    1. **模板引擎**:`Codesmith` 使用模板引擎来生成代码,用户可以根据需要定制自己的模板,模板语言支持多种语法,如`Velocity`或`FreeMarker`,这些模板语言提供了丰富的控制结构,如循环、条件判断等,可以生成...

    codesmith生成实体类简单模板

    3. **编写模板**:在“实体类模板.cst”中,使用CST语法定义实体类的结构。可以定义类头(包括命名空间、类名、访问修饰符等),然后使用循环结构遍历所有列,为每一列生成一个属性。 4. **处理特殊需求**:除了...

    CodeSmith模板

    3. **使用CodeSmith参数**:在模板中引用CodeSmith提供的参数,如数据库表名、列名等,这些参数可以在运行时由CodeSmith自动填充。 4. **处理模板逻辑**:利用C#的控制流语句(如if、for、while等)来处理复杂的逻辑...

    codeSmith 模板

    模板文件通常使用C#语法,并包含一些特殊的CodeSmith指令和变量,这些变量在运行时会被替换为实际的数据。例如,`&lt;#=ClassName#&gt;`会替换为当前实体的类名,`&lt;#=Property.Name#&gt;`会替换为属性的名称。 通过自定义...

    CodeSmith企业版5.22+中文详细注释三层+抽象工厂模板+许可文件+中文件详细教程.part4

    CodeSmith 是一种基于模板的代码生成工具,它使用类似于 ASP.NET 的语法来生成任意类型的代码或文本。与其他许多代码生成工具不同,CodeSmith 不要求您订阅特定的应用程序设计或体系结构。使用 CodeSmith,可以生成...

    用CodeSmith 写的模板

    在描述中的"用CodeSmith 写的模板"可能包括了以下部分: 1. 实体类模板:模板通常会根据数据库表的结构自动生成对应的C#实体类,包括属性、属性类型和注解。例如,对于名为`User`的表,CodeSmith 可能会生成如下...

    codesmith存储过程生成模板

    1. 模板语法:了解并熟练掌握Codesmith的模板语言,如使用`${}`进行变量替换,使用`#foreach()`进行循环,使用`#if()`进行条件判断等。 2. 数据库兼容性:确保生成的存储过程能够运行在目标数据库系统上,因为不同的...

    codeSmith常用模板

    - **模板语言**: CodeSmith使用其自定义的模板语言,允许用户通过简单的语法创建复杂的代码生成逻辑。 - **模板结构**: 模板由文本、控制流(如循环、条件语句)和嵌入的C#代码组成,以`.cshtml`或`.cst`为扩展名...

    带有抽象工厂的Codesmith模板

    使用Codesmith模板,你可以自定义抽象工厂模式的各个组件,包括工厂和产品的接口及实现,然后通过指定的模板语法生成相应的C#代码。这将极大地简化代码编写工作,特别是在需要创建大量相关对象的复杂系统中。 在...

    简单的CodeSmith实体模板

    1. **模板语法**:CodeSmith使用其特有的模板语言,通过一系列控制流语句(如`&lt;#if&gt;`,`&lt;#foreach&gt;`等)和表达式来决定生成的代码结构。模板中的`, `, `#&gt;`等符号分别用于输出变量值、开始代码块和结束代码块。 2. *...

    CodeSmith自动模板

    模板文件通常使用C#语法,并结合CodeSmith特有的语言扩展,如foreach、if等,使得模板具备条件判断和循环等功能。 三层架构是一种常见的软件设计模式,包括表现层(UI)、业务逻辑层(BLL)和数据访问层(DAL)。...

Global site tag (gtag.js) - Google Analytics