data:image/s3,"s3://crabby-images/28f60/28f603fb3dda0087275219eca06b0ff0d6d79fc5" alt="clock"
April 16, 2015 08:42 by
Peter
Today I worked on a project wherever i'm needed to show a picture on the web page with ASP.NET MVC. As you recognize there's not a hypertext markup language Helper for pictures yet. check out the following screen, we will not see a picture here:
data:image/s3,"s3://crabby-images/d97d8/d97d815b3341ad706dbbdc6af5e947368747ec69" alt=""
Before proceeeding during this article, let me share the sample data source here:
Data Source & Controller
data:image/s3,"s3://crabby-images/9b18e/9b18e1c3fc94a8ad42e5f8013a87220fe329190d" alt=""
View
data:image/s3,"s3://crabby-images/b280b/b280b843cdd242b326d53dce4dfd325611f341f7" alt=""
As in the above image, the first one (@Html.DisplayFor…) is generated by scaffolding on behalf of me (marked as a comment within the above view) and the second one is an alternative that may work. So, we do not have a hypertext markup language helper to manage pictures exploitation Razor syntax! We will develop an extension method for this that will allow us to work with pictures. Let's start.
Now, Add a class file using the following code: using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
namespace MvcApplication8.Models
{
public static class ImageHelper
{
public static MvcHtmlString Image(this HtmlHelper helper, string src, string altText, string height)
{
var builder = new TagBuilder("img");
builder.MergeAttribute("src", src); builder.MergeAttribute("alt", altText);
builder.MergeAttribute("height", height);
return MvcHtmlString.Create(builder.ToString(TagRenderMode.SelfClosing));
}
}
}
The above "Image" function has the "MvcHtmlString" type and can settle for a four-parameter helper (helper sort "image"), src (image path), altText (alternative text) and height (height of image) and will return a "MvcHtmlString" type. In the view, comment-out the last line (HTML style approach) and use the new extended technique for the image, as in:
data:image/s3,"s3://crabby-images/29f9d/29f9d572bc660f7b0ce68636e57b0ba58265d987" alt=""
Note: Please note to use "@using MvcApplication8.Models" namespace on every view page to enable this new HtmlHelper. If you set a breakpoint on the extension method then you'll notice that the method returns the exact markup that we need.
data:image/s3,"s3://crabby-images/cd116/cd1166b30d3b0fb42cc95e597a8f8d29b9605806" alt=""
Free ASP.NET MVC Hosting
Try our Free ASP.NET MVC Hosting today and your account will be setup soon! You can also take advantage of our Windows & ASP.NET Hosting support with Unlimited Domain, Unlimited Bandwidth, Unlimited Disk Space, etc. You will not be charged a cent for trying our service for the next 3 days. Once your trial period is complete, you decide whether you'd like to continue.
data:image/s3,"s3://crabby-images/7e17f/7e17f56554a1d52bdd8f7e21aec34204985d80db" alt=""