我目前正在重构一个控制台应用程序,其主要职责是根据存储在数据库中的值生成报告.
我现在创建报告的方式如下:
const string format = ""; if(items.Count > 0) { builder.AppendLine( String.Format(format, "Date", "Id", "WorkItemId", "Account Number", "Name", "Address", "Description")); } foreach(Item item in items) { builder.AppendLine(String.Format(format, item.StartDate, item.Id, item.WorkItemId, item.AccountNumber, String.Format("{0} {1}", item.FirstName, item.LastName), item.Address, item.Description)); } string report = String.Format(" {0, 10} {1} {2, 8} {3} {4, -30} {5} {6}
(以上只是一个示例......并对格式化感到抱歉......我试着将其格式化,因此不需要水平滚动....)
我真的不喜欢这样做我已经这样做了.它现在可以正常工作......但我认为它不可维护......特别是如果报告在需要创建的html方面变得更复杂的话.更糟糕的是,我的团队中的其他开发人员肯定会复制并粘贴我的代码,用于生成HTML报告的应用程序,并且可能会造成可怕的混乱.(我已经看到了这样的恐怖产生!想象一下一个报告函数,它有数百行硬编码的sql来检索报告的细节......它足以让一个成年男子哭!)
然而,虽然我根本不喜欢这个......我只是想不出一个不同的方式去做.
当然必须有办法做到这一点......我很确定.不久前,我在aspx页面中生成表时做了同样的事情,直到有人向我展示我可以将对象绑定到控件并让.NET处理渲染.它将类似于上面代码的可怕代码变成了两三条优雅的优点.
有没有人知道为这个报告创建html的类似方法而不用硬编码html?
使您的应用程序生成包含原始数据的XML文件.然后将外部XSLT应用于包含HTML的外部XSLT.
更多信息:http://msdn.microsoft.com/en-us/library/14689742.aspx