我有一个非常简单的MVC5应用程序,为客户端提供产品页面,并利用在MVC 5中预先构建的基本CRUD操作。
我有一个名为Cakes.cs的模型,因为客户销售蛋糕。相当简单。以下是该模型的代码:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
namespace TastyCakes.Models
{
public class Cakes
{
public int CakesID { get; set; }
public string Name { get; set; }
public string Description { get; set; }
public decimal Price { get; set; }
public string CakeImage
{
get { return Name.Replace(" ", string.Empty) + ".jpg"; }
}
}
}
如您所见,我正在使用一个计算属性来创建每个蛋糕的图像名称。我只需要为每个蛋糕准备1张图片。现在,在我转到我的CRUD页面上编辑蛋糕时,我想添加一个简单的图片上传功能,它将上传一张图片(无需调整大小或缩略图),但我希望强制执行计算属性名称。换句话说:无论用户将其照片命名为什么,我的上传代码都将将其重命名为Cakes.Name(减去任何空格)+“ .jpg”,并保存到“〜Images / Cakes”。
我只需要上传位于实际编辑页面上,因此此时蛋糕已经被创建。从编辑页面中应该可以轻松获取并利用重命名文件所需的所有信息。以下是我的编辑页面代码:
编辑页面:
@model TastyCakes.Models.Cakes
<div class="row">
<div class="large-12 columns">
<hgroup class="title">
<h1>Edit Cakes</h1>
</hgroup>
@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
<div class="form-horizontal">
<hr />
@Html.ValidationSummary(true)
@Html.HiddenFor(model => model.CakesID)
<div class="medium-12 column">
@Html.LabelFor(model => model.Name)
@Html.EditorFor(model => model.Name)
@Html.ValidationMessageFor(model => model.Name)
</div>
<div class="medium-12 column">
@Html.LabelFor(model => model.Description)
@Html.EditorFor(model => model.Description)
@Html.ValidationMessageFor(model => model.Description)
</div>
<div class="medium-12 column">
@Html.LabelFor(model => model.Price)
@Html.EditorFor(model => model.Price)
@Html.ValidationMessageFor(model => model.Price)
</div>
<div class="medium-12 column">
<input type="submit" value="Save" class="tiny button" />
@Html.ActionLink("Back to List", "Index", null, new { @class = "tiny button" })
</div>
</div>
}
@section Scripts {
@Scripts.Render("~/bundles/jqueryval")
}
</div>
</div>
我已经审查了一些html5和ASP.Net 4的解决方案,但这太过复杂了。我想要的非常简单。有什么想法或正确方向的启示将不胜感激。我使用这段代码不仅仅是为了客户的网站,还包括在一个虚构的网站中,用于教授非常基本的MVC概念。