详解ASP.NET MVC 利用Razor引擎生成静态页
最近在研究ASP.NETMVC生成静态页,那么今天也算个学习笔记吧!
实现原理及步骤:
1.通过ViewEngines.Engines.FindView查找到对应的视图,如果是部分视图,则用:ViewEngines.Engines.FindPartialView;
2.设置上下文对象里的Model;
3.调用视图的Render()方法,将渲染结果保存到物理静态文件;
usingSystem; usingSystem.IO; usingSystem.Text; usingSystem.Web.Mvc; namespaceWhir.Foundation.UI { //////描述:静态页面生成帮助类 /// publicclassStaticPageHelper { //////根据View视图生成静态页面 /// ///存放静态页面所在绝对路径 /// ControllerContext /// 视图名称 /// 模板视图名称 /// 参数实体模型 /// 返回信息 /// 是否分布视图 /// 生成成功返回true,失败false publicstaticAjaxResultGenerateStaticPage(stringviewPath, stringhtmlPath, ControllerContextcontext,objectmodel=null,boolisPartial=false, stringmasterName="") { varajaxResult=newAjaxResult(); try { //创建存放静态页面目录 if(!Directory.Exists(Path.GetDirectoryName(htmlPath))) { Directory.CreateDirectory(Path.GetDirectoryName(htmlPath)); } //删除已有的静态页面 if(File.Exists(htmlPath)) { File.Delete(htmlPath); } ViewEngineResultresult=null; if(isPartial) { result=ViewEngines.Engines.FindPartialView(context,viewPath); } else { result=ViewEngines.Engines.FindView(context,viewPath,masterName); } if(model!=null) { context.Controller.ViewData.Model=model; } /* *设置临时数据字典作为静态化标识 *可以在视图上使用TempData["IsStatic"]来控制某些元素显示。 */ if(!context.Controller.TempData.ContainsKey("IsStatic")) { context.Controller.TempData.Add("IsStatic",true); } if(result.View!=null) { using(varsw=newStringWriter()) { varviewContext=newViewContext(context, result.View, context.Controller.ViewData, context.Controller.TempData,sw); result.View.Render(viewContext,sw); stringbody=sw.ToString(); File.WriteAllText(htmlPath,body,Encoding.UTF8); ajaxResult.IsSucess=true; ajaxResult.Body="存放路径:"+htmlPath; } } else { ajaxResult.IsSucess=false; ajaxResult.Body="生成静态页面失败!未找到视图!"; } } catch(IOExceptionex) { ajaxResult.IsSucess=false; ajaxResult.Body=ex.Message; } catch(Exceptionex) { ajaxResult.IsSucess=false; ajaxResult.Body=ex.Message; } returnajaxResult; } } }
AjaxResult是自己封装的一个类,您也可以用自己封装的类代替。
publicclassAjaxResult { publicboolIsSucess{get;set;} publicstringBody{get;set;} }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。