一、什么是T4模板

T4是Text Template Transformation Toolkit(文本模板转换工具包)的四个英文首字母的简称。是微软提供的一种代码生成引擎。

在ADO.NET实体数据模型和EF框架中,那些根据数据库表结构自动生成的代码就是根据这种引擎来生成的,所以当我们对VS自动生成的代码不满意或有特殊需求,则可以修改T4模板来达到目的。

在VS2012中,通过下面步骤可以添加T4模板(以.tt为后缀名):

其中“文本模板”和“运行时文本模板”是微软提供的两种T4模板

当添加一个“文本模板”时,新建的文件中默认会有如下代码:

<#@ template debug="false" hostspecific="false" language="C#" #>
<#@ assembly name="System.Core" #>
<#@ import namespace="System.Linq" #>
<#@ import namespace="System.Text" #>
<#@ import namespace="System.Collections.Generic" #>
<#@ output extension=".txt" #>

二、编写T4文本模板--语法

要学习如何进行T4模板的编写,首先需要了解T4模板的语法。

文本模板由下面三部分组成:

  • 指令:为文本模板转换引擎提供说明
  • 文本块:输出的内容
  • 控制块:向文本块中插入变量或循环等的一些程序代码

2.1指令

指令通常是模板文件或包含的文件中的第一个元素,其语法一般如下所示:<#@  指令名 [属性名=”属性值”] … #>

T4模板包含的指令有:模板指令、输出指令、参数指令、程序集指令、导入指令、包含指令

  • 模板指令

模板指令的一般格式如下:

<#@ template [language="VB"] [hostspecific="true|TrueFromBase"] [debug="true"] [inherits="templateBaseClass"] [culture="code"] [compilerOptions="options"] [visibility="internal"] [linePragmas="false"] #>template指令的所有属性如上所示,这些指令指定了转换的不同方面,并且都是可选的。language属性:有效值是:C#(默认)、VB。 用于指定模板中程序代码所使用的编程语言。hostspecific属性:有效值:true,false(默认),trueFromBase。

若设置为true,则会将名为 Host 的属性添加到由文本模板生成的类中,该属性是对转换引擎的宿主的引用,并声明为 ITextTemplatingEngineHost。

如果已经定义了自定义宿主,则可以将其转换为自定义宿主类型。(关于ITextTemplatingEngineHost的更多内容,请参考:

http://msdn.microsoft.com/zh-cn/library/vstudio/microsoft.visualstudio.texttemplating.itexttemplatingenginehost(v=vs.110).aspx

)

debug属性:有效值:true、false(默认)

如果 debug 特性为 true,则中间代码文件将包含使调试器能够更精确地识别模板中出现中断或异常的位置的信息。对于设计时模板,中间代码文件将写入您的 %TEMP% 目录。

inherits属性

指定模板的程序代码可以继承自另一个类,这个类也可以从文本模板生成。

  • 参数指令

parameter 指令声明模板代码中从自外部上下文传入的值初始化的属性。基本语法:<#@ parameter type="Full.TypeName" name="ParameterName" #>

如:<#@ template language="C#" #> <#@ parameter type="System.Int32" name="TimesToRepeat" #> <# for (int i = 0; i < TimesToRepeat; i++) { #> Line <#= i #> <# } #>

  • 输出指令

output 指令用于定义已转换文件的文件扩展名和编码。基本语法:<#@ output extension=".fileNameExtension" [encoding="encoding"] #>

注:每个文本模板中,不应该有多个output,extension的默认值为”.cs”如:<#@ output extension=".txt" #>

  • 程序集指令

assembly 指令可加载程序集,以便您的模板代码可使用其类型。该作用类似于在 Visual Studio 项目中添加程序集引用。

基本语法:<#@ assembly name="[assembly strong name|assembly file name]" #>,程序集名称应符合下述规范:

GAC 中程序集的强名称,例如 System.Xml.dll。 还可以使用长形式,例如 name="System.Xml, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"。

程序集的绝对路径

  • 导入指令

import 指令允许您在不提供完全限定名称的情况下引用另一个命名空间中的元素,等效于 C# 中的 using

基本语法:<#@ import namespace="namespace" #>

例如:<#@ import namespace="System.IO" #>

注:System命名空间会自动导入

  • 包含指令

通过使用 <#@include#> 指令可包括来自另一个文件的文本。基本语法:<#@ include file="filePath" [once="true"] #>

filePath可以是绝对路径,也可以是相对于模板的路径

2.2控制块

  • 标准控制块

用于控制输出的文件内容。包含在<# … #>标记中

例如:

<#@ template debug="false" hostspecific="false" language="C#" #>
<#@ output extension=".txt" #>

<#
   int top = 10;
   for(int i=0;i<=top;i++)
   {
#>
    The square of <#= i #> is <#= i*i #>
<# 
    }
#>

保存后会输出:

The square of 0 is 0
    The square of 1 is 1
    The square of 2 is 4
    The square of 3 is 9
    The square of 4 is 16
    The square of 5 is 25
    The square of 6 is 36
    The square of 7 is 49
    The square of 8 is 64
    The square of 9 is 81
    The square of 10 is 100

  • 表达式块

表达式控制块用于提供要写入输出文件的字符串的代码,用于变量值的输出。表达式块放于<#= … #>标记中

例如:

The square of <#= i #> is <#= i*i #> 会输出i的值和i*i的值

  • 类功能控制块

可以使用类功能控制块向文本模板添加方法、属性、字段甚至是嵌套类。类功能块最常用来为文本模板中其他部件的代码提供帮助器函数。放于<#+ … #>标记中,该标记需放于模板的最后。

例如:

<#+
private int DoubleNumber(int number)
{
return 2*number; }
#>

the double of <#= i #> is <#= DoubleNumber(i) #>

备注:上述三种标记是不能互相嵌套的。只能是完成一个标记后开启先的标记

2.3文本块

不包含与任何标识中的文本,如:this is the content。

2.4文本模板中的工具方法

  • 写入方法

Write() 和 WriteLine() 方法在标准代码块内追加文本,而不必使用表达式代码块

例如下面的两个代码块

使用表达式块的代码<#
int i = 10;
while (i-- > 0)
{ #>
<#= i #>
<# }
#>

使用WriteLine() 的代码块

<#
int i = 10;
while (i-- > 0)
{
WriteLine((i.ToString()));
}
#>

  • 缩进方法

PushIndent() 方法增加缩进;PopIndent() 方法减少缩进;ClearIndent() 方法删除所有缩进。

  • 错误和警告方法

Error()方法输出错误信息;Warning()方法输出警告信息。如:<#
try
{
string str = null;
Write(str.Length.ToString());
}
catch (Exception e)
{
Error(e.Message);
}
#>2.5 其他

指令名

参数说明

作用

$(ProjectName)

项目的基本名称

获取给定项目的路径

$(solutionName)

解决方案的名称

获取给定解决方案的路径

T4模板之初体验(语法)的更多相关文章

  1. 学习C++模板,初体验

    最近,看了很多码神级人物的代码,发现其代码很炫酷,尤其对模板的使用,作为小码农,感觉已经落伍了,所以应该发奋图强,好好学习和掌握模板这个东西. 模板是什么呢?有人说一个模板就是一个创建类或函数的蓝图或 ...

  2. (4)Flask项目模板渲染初体验

    一.准备静态资源 将项目使用到的静态资源拷贝到static目录 二.创建前台首页html 创建templates/home/home.html页面,内容包含导航和底部版权两部分,中间内容区域为模板标签 ...

  3. C#代码生成工具:文本模板初体验 使用T4批量修改实体框架(Entity Framework)的类名

    转自:http://www.cnblogs.com/huangcong/archive/2011/07/20/1931107.html 在之前的文本模板(T4)初体验中我们已经知道了T4的用处,下面就 ...

  4. ASP.NET Core 3.0 上的gRPC服务模板初体验(多图)

    早就听说ASP.NET Core 3.0中引入了gRPC的服务模板,正好趁着家里电脑刚做了新系统,然后装了VS2019的功夫来体验一把.同时记录体验的过程.如果你也想按照本文的步骤体验的话,那你得先安 ...

  5. Handlebars的基本用法 Handlebars.js使用介绍 http://handlebarsjs.com/ Handlebars.js 模板引擎 javascript/jquery模板引擎——Handlebars初体验 handlebars.js 入门(1) 作为一名前端的你,必须掌握的模板引擎:Handlebars 前端数据模板handlebars与jquery整

    Handlebars的基本用法 使用Handlebars,你可以轻松创建语义化模板,Mustache模板和Handlebars是兼容的,所以你可以将Mustache导入Handlebars以使用 Ha ...

  6. Java8初体验(一)lambda表达式语法

    感谢同事[天锦]的投稿.投稿请联系 tengfei@ifeve.com 本文主要记录自己学习Java8的历程,方便大家一起探讨和自己的备忘.因为本人也是刚刚开始学习Java8,所以文中肯定有错误和理解 ...

  7. Java8初体验(二)Stream语法详解

    感谢同事[天锦]的投稿.投稿请联系 tengfei@ifeve.com 上篇文章Java8初体验(一)lambda表达式语法比 较详细的介绍了lambda表达式的方方面面,细心的读者会发现那篇文章的例 ...

  8. Java8初体验(2):Stream语法详解

    原文出处: 一冰_天锦 上篇文章Java8初体验(1):lambda表达式语法比较详细的介绍了lambda表达式的方方面面,细心的读者会发现那篇文章的例子中有很多Stream的例子.这些Stream的 ...

  9. Java8初体验(1):lambda表达式语法

    原文出处: 一冰_天锦 本文主要记录自己学习Java8的历程,方便大家一起探讨和自己的备忘.因为本人也是刚刚开始学习Java8,所以文中肯定有错误和理解偏差的地方,希望大家帮忙指出,我会持续修改和优化 ...

随机推荐

  1. I2C控制器的Verilog建模之二

    前言:接着上一篇的I2C写操作,今天要实现一个I2C的读操作.虽然在ADV7181B配置内部寄存器时没有必要使用到读操作,但是为了进一步确认寄存器是否在I2C写模块下被正确配置,这一步是必不可少的. ...

  2. appium+python:自己写的一个滑动控件的方式

    #调用方式roll_ele("ID","ele_id","7","up",3)#将控件分为7格,从底部倒数第二格向上滑动 ...

  3. C#中的 正则表达式

    String 类包括许多字符串搜索和替换方法,当你要在较大字符串中定位文本字符串时,可以使用这些方法. 当你希望在较大字符串中定位若干子字符串之一时,或者当你希望在字符串中标识模式时,正则表达式最有用 ...

  4. 记一个PowerShell的方法调用 --ResolveWindowsPrincipal

    没时间系统的学习PowerShell, 只能现学现用. 这段函数调用花了我半个多小时才搞定. 呵呵. 您别笑我, 呵呵. 在这里个例子里, 包括了PowerShell里如下的一些要点: 静态函数的调用 ...

  5. web服务器长连接

    web服务器都提供长连接的方式,所谓长连接就是客户端一次请求完后,不关闭连接,保持一段时间的连接,下次此客户端再次请求时,不用创建新连接,复用所保持的连接即可.从理论上,长连接可以免去大量建立和关闭连 ...

  6. (转)javascript中的对象查找

    本文转自:http://otakustay.com/object-lookup-in-javascript/  ---很棒的一篇文章,作者的其他文章还暂时没读,但相信作者是一个谦虚 谨慎的好工程师 近 ...

  7. 终极优化_详解Win7旗舰版系统中可以关闭的服务

    Win7旗舰版系统是一款功能强大的系统,不过对于很多用户很多功能却使用不上,而支持功能的很多服务也多少占用了系统资源,那么我们可以通过关闭一些不使用的服务来达到让win7系统运行速度加快的目的.下面小 ...

  8. textview 多行 省略号

    TextView自带的可以通过 android:ellipsize="end" android:singleLine="true"实现单行省略,  多行显示: ...

  9. SQLServer 关闭自增长,插入数据

    怎样随心所欲的插入自增长的值? 关闭自增长 Demo 有表 [dbo].[tbl_Message] 其中ID是自增的要随意插入ID的值 (前提:这个Id当然是不存在的,存在也可以删除) SET IDE ...

  10. 《机器学习实战》学习笔记——第2章 KNN

    一. KNN原理: 1. 有监督的学习 根据已知事例及其类标,对新的实例按照离他最近的K的邻居中出现频率最高的类别进行分类.伪代码如下: 1)计算已知类别数据集中的点与当前点之间的距离 2)按照距离从 ...