c#基于NVelocity實(shí)現(xiàn)代碼生成
在框架開發(fā)過程中,通用代碼生成是一項(xiàng)必不可少的功能,c#在這后端模板引擎這方面第三方組件較少,我這里選擇的是NVelocity,現(xiàn)在升級(jí)到了NetStandard2.0,可以用于NetCore項(xiàng)目
添加引用
初始化模板引擎及設(shè)置模板讀取路徑
vltEngine = new VelocityEngine(); vltEngine.SetProperty(RuntimeConstants.RESOURCE_LOADER, "file"); vltEngine.SetProperty(RuntimeConstants.FILE_RESOURCE_LOADER_PATH, CloudUtil.GetContentPath() + "/" + "Template"); vltEngine.Init();
讀取模板渲染結(jié)果
VelocityContext vltContext = new VelocityContext(); foreach (var item in RenderDataDic) { vltContext.Put(item.Key, item.Value); } Template vltTemplate = vltEngine.GetTemplate(TemplateFileName); System.IO.StringWriter vltWriter = new System.IO.StringWriter(); vltTemplate.Merge(vltContext, vltWriter); string CodeContent = vltWriter.GetStringBuilder().ToString();
模板語(yǔ)法
示例Entity模板
using FastORM.Attribute; using FastORM.Entity; using System; using System.Collections.Generic; using System.Text; namespace ${NameSpace}.Entity { [Table(Name = "${TablePhysicalNameLowCase}")] public class ${TablePhysicalName} : BaseEntity { [Key] public string RowGuid { set; get; } #foreach( $Column in $ColumnList) #if (($Column.ColumnType == 10 || $Column.ColumnType == 50) && $Column.PhysicalColumnName!="RowGuid") public string $Column.PhysicalColumnName { set; get; } #end #if ($Column.ColumnType == 20 && $Column.PhysicalColumnName!="RowGuid") public int $Column.PhysicalColumnName { set; get; } #end #if ($Column.ColumnType == 30 && $Column.PhysicalColumnName!="RowGuid") public decimal $Column.PhysicalColumnName { set; get; } #end #if ($Column.ColumnType == 40 && $Column.PhysicalColumnName!="RowGuid") public DateTime? $Column.PhysicalColumnName { set; get; } #end #end } }
常用語(yǔ)法
使用${xxx}占位替換具體字符串內(nèi)容
使用 #foreach( $Itemin $ItemList) #end 來進(jìn)行循環(huán)渲染
使用 #if #end 來進(jìn)行分支判斷渲染
完整工具類代碼
public class TemplateUtil { private static VelocityEngine vltEngine; public static string CodeTempPath; private static void InitTemplateSetting() { CodeTempPath = AppConfigUtil.Configuration["Frame:GenerateCodeTemplatePath"]; DirectoryInfo CodePath = new DirectoryInfo(CloudUtil.GetContentStaticFilePath() + CodeTempPath); if (!CodePath.Exists) { CodePath.Create(); } vltEngine = new VelocityEngine(); vltEngine.SetProperty(RuntimeConstants.RESOURCE_LOADER, "file"); vltEngine.SetProperty(RuntimeConstants.FILE_RESOURCE_LOADER_PATH, CloudUtil.GetContentPath() + "/" + "Template"); vltEngine.Init(); } public static string GeneratemeplateFile(string FileID, string TableName, string TemplateFileName, string CodeFileName, Dictionary<string, object> RenderDataDic) { InitTemplateSetting(); DirectoryInfo CodePath = new DirectoryInfo(CloudUtil.GetContentStaticFilePath() + CodeTempPath + "/" + FileID); if (!CodePath.Exists) { CodePath.Create(); } CodePath = new DirectoryInfo(CloudUtil.GetContentStaticFilePath() + CodeTempPath + "/" + FileID + "/" + TableName); if (!CodePath.Exists) { CodePath.Create(); } VelocityContext vltContext = new VelocityContext(); foreach (var item in RenderDataDic) { vltContext.Put(item.Key, item.Value); } Template vltTemplate = vltEngine.GetTemplate(TemplateFileName); System.IO.StringWriter vltWriter = new System.IO.StringWriter(); vltTemplate.Merge(vltContext, vltWriter); string CodeContent = vltWriter.GetStringBuilder().ToString(); string CodeFilePath = CloudUtil.GetContentStaticFilePath() + CodeTempPath + "/" + FileID + "/" + TableName + "/" + CodeFileName; //保存生成后的代碼內(nèi)容到文件 FileUtil.SaveStringToFile(CodeFilePath, CodeContent); return CodeFilePath; } public static string GenerateTemplateContent(string TemplateFileName, Dictionary<string, object> RenderDataDic) { InitTemplateSetting(); VelocityContext vltContext = new VelocityContext(); foreach (var item in RenderDataDic) { vltContext.Put(item.Key, item.Value); } Template vltTemplate = vltEngine.GetTemplate(TemplateFileName); System.IO.StringWriter vltWriter = new System.IO.StringWriter(); vltTemplate.Merge(vltContext, vltWriter); string CodeContent = vltWriter.GetStringBuilder().ToString(); return CodeContent; } }
以上就是c#基于NVelocity實(shí)現(xiàn)代碼生成的詳細(xì)內(nèi)容,更多關(guān)于NVelocity實(shí)現(xiàn)代碼生成的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- 詳解使用Mybatis-plus + velocity模板生成自定義的代碼
- SiteMesh如何結(jié)合Freemarker及velocity使用
- Vue中JS動(dòng)畫與Velocity.js的結(jié)合使用
- 如何解決SpringBoot2.x版本對(duì)Velocity模板不支持的方案
- SpringBoot與velocity的結(jié)合的示例代碼
- 聊聊JS動(dòng)畫庫(kù) Velocity.js的使用
- springMVC+velocity實(shí)現(xiàn)仿Datatables局部刷新分頁(yè)方法
- 詳解velocity模板使javaWeb的html+js實(shí)現(xiàn)模塊化
- Mybatis velocity腳本的使用教程詳解(推薦)
- JAVA velocity模板引擎使用實(shí)例
- html文件中jquery與velocity變量中的$沖突的解決方法
- Java 如何使用Velocity引擎生成代碼
相關(guān)文章
C#中倒計(jì)時(shí)功能的優(yōu)化方法小結(jié)
這篇文章主要為大家詳細(xì)介紹了當(dāng)C#重復(fù)使用一段代碼倒計(jì)時(shí)時(shí),如何使用普通類和靜態(tài)方法,實(shí)現(xiàn)簡(jiǎn)單的代碼封裝性、可擴(kuò)展性、可維護(hù)性,感興趣的可以了解下2024-01-01從Request.Url中獲取根網(wǎng)址的簡(jiǎn)單操作
這篇文章主要介紹了從Request.Url中獲取根網(wǎng)址的簡(jiǎn)單操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-01-01C# WinForm開發(fā)中使用XML配置文件實(shí)例
這篇文章主要介紹了C# WinForm開發(fā)中使用XML配置文件實(shí)例,本文詳細(xì)講解了如何使用一個(gè)XML文件作為WinForm的配置文件,需要的朋友可以參考下2014-08-08C#中將xml文件反序列化為實(shí)例時(shí)采用基類還是派生類的知識(shí)點(diǎn)討論
在本篇文章里小編給大家整理的是關(guān)于C#中將xml文件反序列化為實(shí)例時(shí)采用基類還是派生類的知識(shí)點(diǎn)討論,有需要的朋友們學(xué)習(xí)下。2019-11-11在C#中g(shù)lobal關(guān)鍵字的作用及其用法
global 是 C# 2.0 中新增的關(guān)鍵字,理論上說,如果代碼寫得好的話,根本不需要用到它,但是不排除一些特別的情況,比如修改別人的代碼,本文僅舉例說明。2016-03-03C#實(shí)現(xiàn)讀取txt通用的方法小結(jié)
這篇文章主要為大家詳細(xì)介紹了C#讀取txt通用的方法,兼容所有的UTF-8、Unicode(Little Endian)、BigEndianUnicode,有需要的小伙伴可以了解下2024-01-01