如何在图像链接中显示图像
本文关键字:图像 显示 显示图 链接 | 更新日期: 2023-09-27 18:29:36
我想创建一个图像链接,但看不到图像这是我的扩展方法:
public static MvcHtmlString ActionImage(this HtmlHelper htmlHelper,
string controller,
string action,
object routeValues,
string imagePath,
string alternateText = "",
object htmlAttributes = null)
{
var anchorBuilder = new TagBuilder("a");
var url = new UrlHelper(htmlHelper.ViewContext.RequestContext);
anchorBuilder.MergeAttribute("href", url.Action(action, controller, routeValues));
var imgBuilder = new TagBuilder("img");
imgBuilder.MergeAttribute("src", url.Content(imagePath));
imgBuilder.MergeAttribute("alt", alternateText);
var attributes = (IDictionary<string, object>)HtmlHelper.AnonymousObjectToHtmlAttributes(htmlAttributes);
imgBuilder.MergeAttributes(attributes);
string imgHtml = imgBuilder.ToString(TagRenderMode.SelfClosing);
anchorBuilder.InnerHtml = imgHtml;
return MvcHtmlString.Create(anchorBuilder.ToString());
}
我在我的观点中使用它:
@foreach (var item in Model)
{
.
.
<div>
Image:
@Html.ActionImage("ControllerName", "action",
"routeValues", item.ImageAddress.toString())
</div>
.
.
}
ImageAddress是字符串,但不起作用,当我使用这样的特定地址时没有区别
@Html.ActionImage("ControllerName", "action",
"routeValues", "C:'1.jpg")
只有当使用这个地址时,它才能正常工作:
"../../Content/Images/1.jpg"
怎么了?谢谢你的帮助,对不起我的英语
浏览器无法从服务器磁盘读取文件。
您只能通过HTTP引用图像。
试试这个:
@foreach (var item in Model)
{
.
.
<div>
Image:
@Html.ActionImage("ControllerName", "action",
"routeValues", @Url.Content("~/" + item.ImageAddress.toString()))
</div>
.
.
}
在这个问题中,我没有使用Extension方法,而是使用img标记。
<img src="@Url.Content("~/Content/Images/" + @item.Id + ".jpg")" />
我在Vahid Nasiri的Ebook中创建了它,学习MVC3。http://www.dotnettips.info/