Asp.net MVC2.0系列文章-添加操作
2013-01-06 10:06
447 查看
此篇文章,我们将实现MVC2.0
的添加操作,主要包括Model
的创建、View
的Edit
操作和Control
的Create
操作。
创建数据模型Model
数据模型主要包括数据信息、验证规则以及业务逻辑。
创建Model
的方式有多种,
可以使用微软的ADO.NET Entity Data Model,也可以使用第三方工具生成实体对象,对于比较简单的实体,我们可以手工添加,此处就是手动敲上去的。
分析:此处定义了新闻实体对象的的一些属性,在每个Property
上都存在一些注解,比如字段Title
上RequiredAttribute,表明Title
栏位是必填字段,如果不填写会显示错误信息
请输入标题!
DataTypeAttribute属性表明此字段的数据类型为文本类型,它是个枚举类型集合,如下:
Member name
Description
Custom
Represents a custom data type.
DateTime
Represents an instant in time, expressed as a date and time of day.
Date
Represents a date value.
Time
Represents a time value.
Duration
Represents a continuous time during which an object exists.
PhoneNumber
Represents a phone number value.
Currency
Represents a currency value.
Text
Represents text that is displayed.
Html
Represents an HTML file.
MultilineText
Represents multi-line text.
EmailAddress
Represents an e-mail address.
Password
Represent a password value.
Url
Represents a URL value.
ImageUrl
Represents a URL to an image.
这些类型,可以分别试试,看看最终效果什么样子的。
DisplayNameAttribute属性表明了此字段要文字说明。
创建View
视图
MVC提供了生成View的向导工具,很方便的,如下图流程步骤:
我们在View文件夹下,新建一个新文件夹,命名为News
右击News文件夹,选择Add-Add View功能菜单,出现如下界面:
在View name栏位,我可以给此视图修改名称,比如AddNews,
选中Create a strongly-typed view 栏位,选择刚才定义的实体类Model,并选择View content栏位为Create操作。
其他栏位默认值就OK
最终效果如下图所示:
单击【Add】按钮,即可添加AddNews.aspx视图成功。此文件的核心代码如下所示:
asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server"
h2
添加新?闻?/h2
% using (Html.BeginForm())
{%
%: Html.ValidationSummary(true) %
fieldset
legend新?闻?/legend
div class="editor-label"
%: Html.LabelFor(model = model.Title) %
/div
div class="editor-field"
%: Html.TextBoxFor(model = model.Title) %
%: Html.ValidationMessageFor(model = model.Title) %
/div
div class="editor-label"
%: Html.LabelFor(model = model.CreateTime) %
/div
div class="editor-field"
%: Html.TextBoxFor(model = model.CreateTime, new { @class = "date" })%
%: Html.ValidationMessageFor(model = model.CreateTime) %
/div
div class="editor-label"
%: Html.LabelFor(model = model.Content) %
/div
div class="editor-field"
%: Html.EditorFor(model = model.Content) %
%: Html.ValidationMessageFor(model = model.Content) %
/div
p
input type="submit" value="添加" /
/p
/fieldset
% } %
div
%: Html.ActionLink("Back to List", "Index","Home") %
/div
/asp:Content
分析:
在日期文本框中,新增加属性new { @class = "date" }),此Class属性是为了稍后的日历控件的显示。要使日期文本框显示日期控件,可以使用Jquery UI,方法是:
1/、Jquery UI官方网站http://www.jqueryUI.com下载最新的 UI类库
2、添加日历控件的CSS文件和JS文件到项目中,如下图
3、在母版页面Site.Master中添加JS的引用,以及页面初始化时绑定日历控件到文本框,代码如下:
link href="http://www.cnblogs.com/Content/jquery.ui.all.css" rel="stylesheet" type="text/css" /
script src="http://www.cnblogs.com/Scripts/jquery-1.4.1.min.js" type="text/javascript"/script
script src="http://www.cnblogs.com/Scripts/jquery-ui-1.8.2.custom.min.js" type="text/javascript"/script
script type="text/javascript"
$(document).ready(function () {
$("input:text.date").datepicker(
{
dateFormat: "yy-mm-dd"
});
});
/script
到此,日历栏位的文本框就可以显示日历控件了,稍后看效果图。
创建Controller
文件
在Controllers
文件夹下,新增News
文件夹;
单击右键,选择Add-Controller
,显示如下界面
重命名Controller Name
栏位为NewsController
,同时选择下方的复选框,最终效果如下图:
单击【Add
】按钮,自动产生Controller
中的一些方法,这时候对Controller
中的方法做一些修改,即可完成添加新闻页面初始化的方法,以及添加新闻功能,代码如下:
// GET: /News/Create
//完成页面初始化
public ActionResult AddNews()
{
return View();
}
//
// POST: /News/Create
//完成添加按钮事件
[HttpPost]
public ActionResult AddNews(THelperMVC.Models.News.AddNewsModel news)
{
if (ModelState.IsValid)
{
newsService.AddNews();
return RedirectToAction("index", "Home");
}
else
{
ModelState.AddModelError("", "请?输?入?合?法的?信?息!?");
}
return View(news);
}
至此,MVC
的各个层次都已经创建完,让我们看看最终的效果吧。
程序效果图
的添加操作,主要包括Model
的创建、View
的Edit
操作和Control
的Create
操作。
创建数据模型Model
数据模型主要包括数据信息、验证规则以及业务逻辑。
创建Model
的方式有多种,
可以使用微软的ADO.NET Entity Data Model,也可以使用第三方工具生成实体对象,对于比较简单的实体,我们可以手工添加,此处就是手动敲上去的。
分析:此处定义了新闻实体对象的的一些属性,在每个Property
上都存在一些注解,比如字段Title
上RequiredAttribute,表明Title
栏位是必填字段,如果不填写会显示错误信息
请输入标题!
DataTypeAttribute属性表明此字段的数据类型为文本类型,它是个枚举类型集合,如下:
Member name
Description
Custom
Represents a custom data type.
DateTime
Represents an instant in time, expressed as a date and time of day.
Date
Represents a date value.
Time
Represents a time value.
Duration
Represents a continuous time during which an object exists.
PhoneNumber
Represents a phone number value.
Currency
Represents a currency value.
Text
Represents text that is displayed.
Html
Represents an HTML file.
MultilineText
Represents multi-line text.
EmailAddress
Represents an e-mail address.
Password
Represent a password value.
Url
Represents a URL value.
ImageUrl
Represents a URL to an image.
这些类型,可以分别试试,看看最终效果什么样子的。
DisplayNameAttribute属性表明了此字段要文字说明。
创建View
视图
MVC提供了生成View的向导工具,很方便的,如下图流程步骤:
我们在View文件夹下,新建一个新文件夹,命名为News
右击News文件夹,选择Add-Add View功能菜单,出现如下界面:
在View name栏位,我可以给此视图修改名称,比如AddNews,
选中Create a strongly-typed view 栏位,选择刚才定义的实体类Model,并选择View content栏位为Create操作。
其他栏位默认值就OK
最终效果如下图所示:
单击【Add】按钮,即可添加AddNews.aspx视图成功。此文件的核心代码如下所示:
asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server"
h2
添加新?闻?/h2
% using (Html.BeginForm())
{%
%: Html.ValidationSummary(true) %
fieldset
legend新?闻?/legend
div class="editor-label"
%: Html.LabelFor(model = model.Title) %
/div
div class="editor-field"
%: Html.TextBoxFor(model = model.Title) %
%: Html.ValidationMessageFor(model = model.Title) %
/div
div class="editor-label"
%: Html.LabelFor(model = model.CreateTime) %
/div
div class="editor-field"
%: Html.TextBoxFor(model = model.CreateTime, new { @class = "date" })%
%: Html.ValidationMessageFor(model = model.CreateTime) %
/div
div class="editor-label"
%: Html.LabelFor(model = model.Content) %
/div
div class="editor-field"
%: Html.EditorFor(model = model.Content) %
%: Html.ValidationMessageFor(model = model.Content) %
/div
p
input type="submit" value="添加" /
/p
/fieldset
% } %
div
%: Html.ActionLink("Back to List", "Index","Home") %
/div
/asp:Content
分析:
在日期文本框中,新增加属性new { @class = "date" }),此Class属性是为了稍后的日历控件的显示。要使日期文本框显示日期控件,可以使用Jquery UI,方法是:
1/、Jquery UI官方网站http://www.jqueryUI.com下载最新的 UI类库
2、添加日历控件的CSS文件和JS文件到项目中,如下图
3、在母版页面Site.Master中添加JS的引用,以及页面初始化时绑定日历控件到文本框,代码如下:
link href="http://www.cnblogs.com/Content/jquery.ui.all.css" rel="stylesheet" type="text/css" /
script src="http://www.cnblogs.com/Scripts/jquery-1.4.1.min.js" type="text/javascript"/script
script src="http://www.cnblogs.com/Scripts/jquery-ui-1.8.2.custom.min.js" type="text/javascript"/script
script type="text/javascript"
$(document).ready(function () {
$("input:text.date").datepicker(
{
dateFormat: "yy-mm-dd"
});
});
/script
到此,日历栏位的文本框就可以显示日历控件了,稍后看效果图。
创建Controller
文件
在Controllers
文件夹下,新增News
文件夹;
单击右键,选择Add-Controller
,显示如下界面
重命名Controller Name
栏位为NewsController
,同时选择下方的复选框,最终效果如下图:
单击【Add
】按钮,自动产生Controller
中的一些方法,这时候对Controller
中的方法做一些修改,即可完成添加新闻页面初始化的方法,以及添加新闻功能,代码如下:
// GET: /News/Create
//完成页面初始化
public ActionResult AddNews()
{
return View();
}
//
// POST: /News/Create
//完成添加按钮事件
[HttpPost]
public ActionResult AddNews(THelperMVC.Models.News.AddNewsModel news)
{
if (ModelState.IsValid)
{
newsService.AddNews();
return RedirectToAction("index", "Home");
}
else
{
ModelState.AddModelError("", "请?输?入?合?法的?信?息!?");
}
return View(news);
}
至此,MVC
的各个层次都已经创建完,让我们看看最终的效果吧。
程序效果图
相关文章推荐
- Asp.net MVC2.0系列文章-添加操作
- Asp.net MVC2.0系列文章-添加操作
- Asp.net MVC2.0系列文章-添加操作
- Asp.net MVC2.0系列文章-添加操作
- Asp.net MVC2.0系列文章-添加操作
- Asp.net MVC2.0系列文章-编辑和删除新闻操作
- Asp.net MVC2.0系列文章-显示列表和详细页面操作
- Asp.net MVC2.0系列文章-显示列表和详细页面操作
- Asp.net MVC2.0系列文章-编辑和删除新闻操作
- Asp.net MVC2.0系列文章-显示列表和详细页面操作
- 关联事件,向窗体中添加控件,设置控件属性等系列操作
- B树系列文章(1)--查询操作
- Flex与.NET互操作系列文章(转)
- 使用iTextSharp在Asp.Net中操作PDF系列文章 目录
- B树系列文章(2)--插入操作
- Flex与.NET互操作系列文章目录
- 从0开始学习 GitHub 系列之「07.GitHub 常见的几种操作」----转载自stormzhang 原创文章
- B树系列文章(3)--删除、更新操作
- .NET RIA Service入门系列文章五:Silverlight 3操作数据库
- Asp.net MVC2.0系列文章-MVC简介篇