ASP.NET MVC 2框架试用经验谈

本文将为大家介绍已经发布的ASP.NET MVC 2框架正式版的使用情况,包括缓存,静态内容的放置等等。希望本文能对大家有所帮助。

创新互联网站建设公司,提供做网站、成都网站制作,网页设计,建网站,PHP网站建设等专业做网站服务;可快速的进行网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,是专业的做网站团队,希望更多企业前来合作!

这个月一直在用 ASP.NET MVC 2 做http://www.86e0.com/t 这个网站,用的时候是 aps.net MVC2 RC2,然后现在ASP.NET MVC 2正式版已经是发布了。 在MVC的使用上,有一些心得。下面作一下总结,希望对大家有用,也欢迎大家讨论。

1.关于缓存

缓存上,数据层上的缓存是必须的,这点不必多说了。

另一个很重要的是:视图片段缓存。

我参考了老赵的写的三篇关于片段缓存的文章:

适合ASP.NET MVC的视图片断缓存方式(上):起步

适合ASP.NET MVC的视图片断缓存方式(中):更实用的API

适合ASP.NET MVC的视图片断缓存方式(下):页面输出原则

本想用老赵的了,但是我发现ASP.NET MVC 2 的有一个新功能: Html.Partial可以返回生成的HTML, 返回的类型是:MvcHtmlString. 虽然要利用Partial View才能生成Html片段,但是我想这个已经够我用的了, 所以我做了一个这样一个Helper,主要是将生成的HTML片段缓存到Memcached里。代码如下:

 
 
 
 
  1. public static class MvcHtmlHelper   
  2. {   
  3. public static MvcHtmlString MemcacheHtmlPartial(this HtmlHelper htmlHelper,int duration, string partialViewName, object model, ViewDataDictionary viewData)   
  4. {   
  5. object obaear = htmlHelper.ViewContext.RouteData.DataTokens["area"];   
  6. string area=string.Empty;   
  7. if (obaear != null) area = obaear.ToString();   
  8. string key = string.Format("MemcacheHtmlPartial_{0}{1}", area, partialViewName);   
  9. object ob = DistCache.Get(key);   
  10. if (ob == null)   
  11. {   
  12.  MvcHtmlString mstr = htmlHelper.Partial(partialViewName, model, viewData);   
  13.  DistCache.Add(key, mstr.ToString(), TimeSpan.FromSeconds(duration));   
  14. return mstr;   
  15. }   
  16. else 
  17. {   
  18.  return MvcHtmlString.Create((string)ob);   
  19. }   
  20.  }   

然后,我觉得,这样,在每次请求时,还是要在Controller 里把数据取出来,然后再传到 Partial View里。 既然已经缓存了,就应该不用每次请求都要在Controller里把数据取出来才对!虽然数据层会有缓存。

所以我,能不能再省下去Controller取数据的消耗,于是又有了以下代码,其功能是:缓存Action生成的HTML到Memcached里。

 
 
 
 
  1. public static MvcHtmlString MemcacheHtmlRenderAction(this HtmlHelper htmlHelper, 
  2. int duration, string actionName,string controllerName, RouteValueDictionary routeValues)   
  3. {   
  4. object obaear = htmlHelper.ViewContext.RouteData.DataTokens["area"];   
  5. string area = string.Empty;   
  6. if (obaear != null) area = obaear.ToString();   
  7. string key = string.Format("MemcacheHtmlRenderAction_{0}{1}{2}", area, controllerName,actionName);   
  8. object ob = DistCache.Get(key);   
  9.  if (ob == null)   
  10.  {   
  11.  // htmlHelper.RenderAction(actionName, controllerName, routeValues);   
  12. StringWriter writer = new StringWriter(CultureInfo.CurrentCulture);   
  13.  ActionHelper(htmlHelper, actionName, controllerName, routeValues, writer);   
  14. string wStr = writer.ToString();   
  15. DistCache.Add(key, wStr,TimeSpan.FromSeconds(duration));   
  16. MvcHtmlString mstr = MvcHtmlString.Create(wStr);   
  17. return mstr;   
  18.  }   
  19. else { return MvcHtmlString.Create((string)ob); }   

说明一下,Actionhelper的方法是在MVC原代码里提取出来的。 因为MVC2里的 Html.RenderAction方法并没有返回 MvcHtmlString的重载版。那位有更好的方法?

其实,MVC里的Action有输出缓存,所以直接在View里用 Html.RenderAction都可以解决很多问题了。这个主要是可以用程序管理缓存。

2.关于静态内容的放置

习惯上,静态内容会放在 mvc程序所在的目录下,比如说js,css,上传的图片等。但是这样的话,所有的静态请求都要经过 aspnet_isapi 处理,这样是非常不合算的。所以静态内容一般都会放在另外的子域上。http://www.86e0.com/t 是放在 cdn.86e0.com上。

3.关于强类型ViewModel

我基本上看了老赵的Asp.net MVC***实践。 其中有一点,就是强烈推荐使用强类型的ViewModel. 我试了一些页面,发现用强类型的ViewModel,现阶段并不适用于我。因为我是用NbearLite,从数据库抓出来的大多是DataTable. 我是觉得DataTable+NbearLite蛮方便的,虽然没有动态语言的数据访问来得方便,但是比用Entity,ViewModel, DTO,等等来说,还是可以省下很多代码。然后,最重要的是,由于我这种站经常会修改,所以数据库改变,加字段,减字段是很经常性的事。但是,用NbearLite + DataSet,DataTable,却非常方便。

所以我觉得,做Asp.net MVC,如果你不是用DDD,DDT的话,用DataTable还是可以的。因为DDD,DDT学习起来还是要点成本的。

4.关于URL生成

URL生成, 老赵写了一系列文章:

各种URL生成方式的性能对比

各种URL生成方式的性能对比(结论及分析)

为URL生成设计流畅接口(Fluent Interface)

URL生成方式性能优化结果

我直接选择

Raw方式了, 速度最快的,才是适合我的。呵。 而不是强类型的才是适合我的。

***,分享一个很实用的Asp.net MVC 分页Helper.

这个Helper引自重典老大的blog:http://www.cnblogs.com/chsword/ . 我在之前做了少少修改,现已经在http://www.86e0.com/t 上使用了。

效果如下:

请大家注意生成的 URL, 是用 ?参数=页码 的方式。代码如下:

 
 
 
 
  1. ///    
  2. /// 分页Pager显示   
  3. ///    
  4. ///    
  5. /// 标识当前页码的QueryStringKey   
  6. /// 每页显示   
  7. /// 总数据量   
  8. ///    
  9. public static string Pager(this HtmlHelper html, string currentPageStr, int pageSize, int totalCount)   
  10.  {   
  11. var queryString = html.ViewContext.HttpContext.Request.QueryString;   
  12. int currentPage = 1; //当前页   
  13. if(!int.TryParse(queryString[currentPageStr], out currentPage)) currentPage = 1; //与相应的QueryString绑定   
  14.  var totalPages = Math.Max((totalCount + pageSize - 1) / pageSize, 1); //总页数   
  15. var dict = new RouteValueDictionary(html.ViewContext.RouteData.Values);   
  16. var output = new StringBuilder();   
  17. foreach (string key in queryString.Keys)   
  18. if (queryString[key] != null && !string.IsNullOrEmpty(key))   
  19. dict[key] = queryString[key];   
  20. if (totalPages > 1)   
  21. {   
  22. if (currentPage != 1)   
  23. {//处理首页连接   
  24. dict[currentPageStr] = 1;   
  25. output.AppendFormat("{0}", html.RouteLink("首页", dict));   
  26.  }   
  27.  if (currentPage > 1)   
  28. {//处理上一页的连接   
  29. dict[currentPageStr] = currentPage - 1;   
  30. output.AppendFormat("{0}", html.RouteLink("上一页", dict));   
  31. }   
  32.  else 
  33. {   
  34.  output.AppendFormat("{0}","上一页");   
  35.   }   
  36. int currint = 5;   
  37.  for (int i = 0; i <= 10; i++)   
  38.  {//一共最多显示10个页码,前面5个,后面5个   
  39. if ((currentPage + i - currint) >= 1 && (currentPage + i - currint) <= totalPages)   
  40.  if (currint == i)   
  41. {//当前页处理   
  42.  output.Append(string.Format("{0}", currentPage));   
  43.  }   
  44.  else 
  45.   {//一般页处理   
  46. dict[currentPageStr] = currentPage + i - currint;   
  47. output.AppendFormat("{0}",html.RouteLink((currentPage + i - currint).ToString(), dict));   
  48.    }   
  49.    }   
  50.  if (currentPage < totalPages)   
  51.    {//处理下一页的链接   
  52.     dict[currentPageStr] = currentPage + 1;   
  53.      output.AppendFormat("{0}", html.RouteLink("下一页", dict));   
  54.    }   
  55.     else 
  56.       {   
  57.       output.AppendFormat("{0}", "下一页");   
  58.    }   
  59.    if (currentPage != totalPages)   
  60.     {   
  61.    dict[currentPageStr] = totalPages;   
  62.      output.AppendFormat("{0}",html.RouteLink("末页", dict));   
  63.    }   
  64.     }   
  65.   output.AppendFormat("第{0}页/共{1}页", currentPage, totalPages);//这个统计加不加都行   
  66.    return output.ToString();   
  67.   }  

ASP.NET MVC延伸阅读

ASP.NET MVC是微软官方提供的MVC模式编写ASP.NET Web应用程序的一个框架。

它由Castle的MonoRail而来.目前已经历经数个版本。ASP.NET MVC中的MVC本来是存在于Desktop程序中的,M是指数据模型,V是指用户界面,C则是控制器。使用MVC的目的是将M和V的实现代码分离,从而使同一个程序可以使用不同的表现形式。比如一批统计数据你可以分别用柱状图、饼图来表示。C存在的目的则是确保M和V的同步,一旦M改变,V应该同步更新。

ASP.NET MVC框架是既ASP.NET WebForms后的又一种开发方式。它提供了一系列优秀特性,使ASP.NET开发人员拥有了另一个选择。ASP.NET MVC框架选项非常干净,而且容易使用。它将允许你在应用中轻易地保持关注分离,且有助于进行干净的测试和TDD。

名称栏目:ASP.NET MVC 2框架试用经验谈
URL网址:http://www.mswzjz.cn/qtweb/news14/401364.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能