c html帮助器,的HTML帮助器

本文介绍如何在ASP.NET MVC中创建一个自定义的HtmlHelper扩展方法`FileFor`,用于处理表单中的文件上传。通过这个扩展,可以方便地生成具有唯一ID的输入元素,并确保在模型中正确绑定到`HttpPostedFileBase`属性。同时,文章还展示了如何配置表单以支持`multipart/form-data`类型的数据提交。
摘要由CSDN通过智能技术生成

Or you could do it properly:

In your HtmlHelper Extension class:

public static MvcHtmlString FileFor(this HtmlHelper helper, Expression> expression)

{

return helper.FileFor(expression, null);

}

public static MvcHtmlString FileFor(this HtmlHelper helper, Expression> expression, object htmlAttributes)

{

var builder = new TagBuilder("input");

var id = helper.ViewContext.ViewData.TemplateInfo.GetFullHtmlFieldName(ExpressionHelper.GetExpressionText(expression));

builder.GenerateId(id);

builder.MergeAttribute("name", id);

builder.MergeAttribute("type", "file");

builder.MergeAttributes(new RouteValueDictionary(htmlAttributes));

// Render tag

return MvcHtmlString.Create(builder.ToString(TagRenderMode.SelfClosing));

}

This line:

var id = helper.ViewContext.ViewData.TemplateInfo.GetFullHtmlFieldName(ExpressionHelper.GetExpressionText(expression));

Generates an id unique to the model, you know in lists and stuff. model[0].Name etc.

Create the correct property in the model:

public HttpPostedFileBase NewFile { get; set; }

Then you need to make sure your form will send files:

@using (Html.BeginForm("Action", "Controller", FormMethod.Post, new { enctype = "multipart/form-data" }))

Then here's your helper:

@Html.FileFor(x => x.NewFile)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值