2012年9月24日星期一

Asp.net MVC4与Razor呈现图片的扩展

Asp.net MVC4与Razor呈现图片的扩展

        我们基于Asp.net MVC 4 Web Application 写一个扩展方法来呈现图片的扩展。Gravatar是提供个人Profile信息的网站,包括图片LOGO。你可以引用你的Profile到论坛,Blog都可以。
        一开始我们写一个Helper如下:

   1:  namespace MVC4Demo.Extensions
   2:  {
   3:      using System;
   4:      using System.Web.Mvc;
   5:      using System.Web.Security;
   6:   
   7:      public static class GravatarHtmlHelperExtensions
   8:      {
   9:          /// <summary>
  10:          /// Gets the Gravatar image URL.
  11:          /// </summary>
  12:          /// <param name="emailId">The email id.</param>
  13:          /// <param name="imgSize">Size of the img.</param>
  14:          /// <seealso cref="https://en.gravatar.com/"/>
  15:          /// <returns>Image MvcHtmlString</returns>
  16:          public static MvcHtmlString RenderGravatarImage(this HtmlHelper helper, string emailId, int imgSize)
  17:          {
  18:              if (string.IsNullOrEmpty(emailId))
  19:                  throw new ArgumentNullException("Email Id should not be null!");
  20:   
  21:              // Convert emailID to lower-case
  22:              emailId = emailId.ToLower();
  23:   
  24:              string hash = FormsAuthentication.HashPasswordForStoringInConfigFile(emailId, "MD5").ToLower();
  25:   
  26:              // build Gravatar Image URL
  27:              string imageUrl = string.Format(@"<img src=""http://www.gravatar.com/avatar/{0}?s={1}&d=mm&r=g"" />", hash, imgSize);
  28:   
  29:              return new MvcHtmlString(imageUrl);
  30:          }
  31:      }
  32:  }


接在Razor的Web.config中加入相应的Namespace:

  <system.web.webPages.razor>
    <host factoryType="System.Web.Mvc.MvcWebRazorHostFactory, System.Web.Mvc, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
    <pages pageBaseType="System.Web.Mvc.WebViewPage">
      <namespaces>
        <add namespace="System.Web.Mvc" />
        <add namespace="System.Web.Mvc.Ajax" />
        <add namespace="System.Web.Mvc.Html" />
        <add namespace="System.Web.Optimization"/>
        <add namespace="System.Web.Routing" />
        <add namespace="MVC4Demo.Extensions"/>
      </namespaces>
    </pages>
  </system.web.webPages.razor>


然后在页面cshtml上我们可以这样使用了:

<div class="Author" style="position:relative;">   
<div style="position:absolute; top:10px;">       
 @Html.RenderGravatarImage(Model.AuthorEmail, 100)    
</div>


如果您对Asp.net MVC 4 Web Application有一定了解,上面的代码并不难懂,这里也只是非常简单的一个示例。希望对您开发有帮助。

您可能感兴趣的文章:

Asp.net MVC3扩展之Ajax异常处理特性


作者:Petter Liu
出处:http://www.cnblogs.com/wintersun/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
该文章也同时发布在我的独立博客中-Petter Liu Blog。


TAG: