博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
EF CodeFirst 使用T4模板 生成文件
阅读量:4313 次
发布时间:2019-06-06

本文共 2513 字,大约阅读时间需要 8 分钟。

小编是个实用主义者,并没有深入的去理解T4的原理。只是根据自己的需求,在博客园里的前辈哪里找的资料,结合自己的理解,在项目中使用了T4模板。

最近的项目用了他,很方便,节省了不少代码量。

 

想利用T4做个代码生成器,目前比较忙,使用一直没有时间去做。如果大家有好的思路或者方法,请多多指教。

 

小编比较懒,又不怎么会排版,所以就先截下图,让大家可以比较直观的先看看需要哪些文件和步骤。

 

首先,定义一个接口,代表一个领域实体。在定义一个实体集成这个接口

面向接口编程的各种好处就不提了。

///     /// 代表一个领域实体    ///     public interface IEntity    {        Guid ID { get; }    }    public abstract class Entity : IEntity    {        public Guid ID { get; set; }        //这里可以写一些领域实体的基本方法。面向对象么 有时总会有写对象自己的公用的方法.类似 freamework的 Object    }    public class User : Entity    {    }

  

 之后新建一个T4模板文件。先上代码后面解释下关键的地方

<#@ template debug="false" hostspecific="true" language="C#" #><#@ assembly name="System.Core" #><#@ assembly name="$(SolutionDir)\Model\bin\Debug\Model.dll" #><#@ import namespace="Model" #><#@ import namespace="System.Linq" #><#@ import namespace="System.Text" #><#@ import namespace="System.Collections.Generic" #><#@ import namespace="System.IO"#><#@ import namespace="System"#><#@ import namespace="System.Configuration"#>   <#@ output extension=".cs" #><#@include file="$(SolutionDir)\packages\MultipleOutputHelper.ttinclude"#> <# 	var assembly = System.Reflection.Assembly.GetAssembly(typeof(IEntity));	var types = assembly.GetTypes().Where(x => typeof(IEntity).IsAssignableFrom(x) && !x.IsAbstract && !x.IsInterface);	var manager = Manager.Create(Host, GenerationEnvironment);  		foreach (var type in types)		{		   			// 定义输出文件			manager.StartNewFile(type.Name+"TypeConfiguration.cs");#>using System.ComponentModel.DataAnnotations.Schema;using System.Data.Entity.ModelConfiguration;using Model;namespace Data{    public class <#=type.Name#>TypeConfiguration : EntityTypeConfiguration<<#=type.Name#>>    {        public <#=type.Name#>TypeConfiguration()        {            HasKey(c => c.ID);            Property(c => c.ID)                .IsRequired()                .HasDatabaseGeneratedOption(DatabaseGeneratedOption.Identity);                     ToTable("<#=type.Name#>");        }    }}<#     // 结束输出文件    manager.EndBlock(); }     // 执行编译    manager.Process(true);   #>

  

<#@ assembly name="$(SolutionDir)\Model\bin\Debug\Model.dll" #>//这个事为了获取领域实体所在的dll文件。之后需要反射这个dll获取集成实体接口。

  

$(SolutionDir)  //这个是VS的宏命令,获取当前的解决方案路径。有不少的宏命令,具体可以找博客园里找下相关的内容,这里就不列举出来了。
 
<#@ import namespace="Model" #>   //引用这个这个dll。类似using

  

<#@include file="$(SolutionDir)\packages\MultipleOutputHelper.ttinclude"#>//这个文件很关键,是个老外写的,具体在哪里找不到了。她会帮助我们生成cs文件。这个文件在我上传附件的packages里面。

 

之后的步骤就是反射的操作了。

写得有些。。。望大家多见谅。

附件 : 

 

转载于:https://www.cnblogs.com/since87/p/3963654.html

你可能感兴趣的文章
C#基础(string)
查看>>
JavaScript-06-Dom操作
查看>>
MYSQL变量
查看>>
8、颠倒任意一个字符串的X个字符(第一个和倒数第一个颠倒,第二个和倒数第二个颠倒 ... )...
查看>>
mysql之索引
查看>>
openlayers3设置zoom不变
查看>>
vector
查看>>
怎样花两年时间去面试一个人
查看>>
算法速成系列
查看>>
The Pilots Brothers' refrigerator(dfs)
查看>>
usb 编程知识 总结
查看>>
iOS-OC-基础-NSString常用方法
查看>>
python-字典(第二篇(四):字典)
查看>>
http 4中 cache 头
查看>>
类加载器-双亲委派模型
查看>>
HDU5649 DZY Loves Sorting 线段树
查看>>
Python学习---range/for/break/continue简单使用
查看>>
一位父亲对儿子的忠告
查看>>
2、session的创建和销毁
查看>>
HTML入门
查看>>