asp.net mvc 3.0 知识点整理 ----- (3).HtmlHelper(Html 辅助方法)介绍
在View视图中,Html的类型是System.Web.Mvc.HtmlHelper<T>, 所有的辅助方法都需要和ModelState交互。那么,ModelState是什么呢?它是模型绑定的附属品,并且存有模型绑定期间检测到的所有验证错误。以及用户提交用到来更新模型的原始值。
本篇博文,我们主要来介绍下一些常用的html辅助方法的主要作用和使用方法。
1. Html.BeginForm()和Ajax.BeginForm()。
Html.BeginForm():
同于传统的表单提交,主要是生成表单的form值,如果表单时强类型视图,则在提交表单的时候,会自动将表单元素name名称与强类型视图中的类型实体的属性值相同的进行填充;同样在表单中,如果我们是强类型视图,则可以直接使用@Model.UserName将值输到指定位置。
@using( Html.BeginForm( "方法名", "Controller名", FormMethod.提交的方法, new { target="_blank", @class = "表单的class名,方便定义样式", @id="表单的id名,方便获取表单元素"} )){ }
<form action="Controller名/方法名" method ="提交的方法" class ="表单的class名" id="表单的id名" target="_blank"></form>
@using(Ajax.BeginForm(
new AjaxOptions
{
UpdateTartetId ="UserLogOnContainer",
HttpMethod ="Post",
OnSuccess=""
}
)) //提交到当前页面,提交方式是Post,异步更新模块Id为UserLogOnContainer的内容块
也可以提交到指定的controller的action上。
@using(Ajax.BeginForm("action","controller",null
new AjaxOptions
{
UpdateTartetId ="UserLogOnContainer",
HttpMethod ="Post",
OnSuccess=""
}
)) //提交到当前指定的controller的action下,提交方式是Post,异步更新模块Id为UserLogOnContainer的内容块
2. Html.ValidationSummary()
@Html.ValidationSummary(true, "Login was unsuccessful. Please correct the errors and try again.")
Controller可以写:
ModelState.AddModelError("", "The user name or password provided is incorrect.");
3.Html.ValidationMessage()
ModelState.AddModelError("Title","What a terrible name!");
@Html.ValidationMessage("Title")
4.Html.TextBox()、Html.TextArea()
@Html.TextBox("title","textbox infomation")
@Html.TextArea("textAreaTitle","textarea <br/> infomation")
<input type="text" id="title" name="title">
textbox information
</input>
< textarea id="textAreaTitle" name="textAreaTitle">
textarea < br /> information
</textarea >
[DisplayName("Genre")] //显示的内容
public int GenreId{get;set;}
View:
@Html.Label("GenreId")
<label for="GenreId">Genre</label>
6.Html.DropDownList()、Html.ListBox()
两个辅助方法都返回select元素,DropDownList只允许多单选,而ListBox则允许多选
(通过渲染的标记中的multiple特性的值设置为multiple), 后台绑定数据源一般使用SelectListItem类型。
new SelectListItem
{
Text = ”显示内容“,
Value = "对应的值",
Selected = bool值(是否选中)
}
7.Html.Editor()
用法:自定义Editor编辑器。
具体使用方法,可以参考这篇文章: http://hi.baidu.com/scorpio_jone/item/3080aefc8133c713a7298843
8.Html.Hidden()
用于渲染隐藏的输入元素,一般用于在页面显示隐藏域。
用法:
@Html.Hidden("wizardStep", "")
=>
@Html.HiddenFor(w => w.wizardStep)
<input id="wizardStep" name="wizardStep" type="hidden" value="1" />
9.Html.Password()
@Html.Password("UserPassword")
=>
@Html. PasswordFor(w => w.UserPassword)
<input id="UserPassword" name="UserPassword" type="password" value="" />
10.Html.RadioButton()
@Html.RadioButton("Gender","Male")
@Html.RadioButton("Gender","Female", true)
@Html.RadioButtonFor(m => m.Gender, "Male")
@Html.RadioButtonFor(m => m.Gender, "Female")
11.Html.CheckBox()
@Html.CheckBox("isChecked")
<input name="isChecked" id="isChecked" type="checkbox" value="true" />
<input name="isChecked" type="hidden" value="false"/>
(这样的原因是:当没选中的时候,确保有值提交。)
@Html.ActionLink("Link Text 显示的链接名称", "AnotherAction 要提交的控制器方法名称")
<a href="/Home/AnotherAction">Link Text</a>
@Html.ActionLink("Link Text", "AnotherAction", "AnotherController")
<a href="/AnotherController/AnotherAction">Link Text</a>
@Html.ActionLink("Link Text", "AnotherAction", "AnotherController", new{ ID = 123 } )
对应于:
<a href="/AnotherController/AnotherAction?ID=123">Link Text</a>
@Html.RouteLink(
linkText: "route:Test",
rountName: "test",
routeValues: new{controller="section", action="Index", id=123 }
)
@{ Html.RenderPartial("LogOnUserControl"); }
或
@{ Html.RenderPartial("~/Areas/Comm/Views/Shared/LogOnUserControl.ascx"); }
public ActionResult UserControl()
{
return PartialView();
}
@Html.RenderAction("UserControl","Controller")
15.Url.Action()
<span>
@Url.Action("Browse", "Store", new{ genre = "Jazz" }, null )
</span>
<span>
Store/Browse?genre=Jazz
</span>
16.Url.Content()
<script src="@Url.Content("~/Scripts/Jquery-1.10.1.min.js")" type="text/javescript"></script>
除了上面介绍的这些Html辅助方法,还有上面提到的一些Html的For方法。那么For方法和其他的有什么异同之处呢?
For的方法可以结合Model实体,通过lambda表达式的方法来渲染。写法:@Html.LabelFor(m => m.GenreId)等。
asp.net mvc 3.0 知识点整理 ----- (3).HtmlHelper(Html 辅助方法)介绍的更多相关文章
- asp.net mvc 3.0 知识点整理 ----- (4).asp.net mvc 3 和asp.net mvc 4 对比
asp.net mvc的版本更新很快,每个版本都在前一个版本的基础上,进行性能的优化和功能的完善和提升. 以下,便是我对比了下两个版本,发现最基本的差异.(更新补充中..) 一.关于配置类Global ...
- asp.net mvc 3.0 知识点整理 ----- (2).Controller中几种Action返回类型对比
通过学习,我们可以发现,在Controller中提供了很多不同的Action返回类型.那么具体他们是有什么作用呢?它们的用法和区别是什么呢?通过资料书上的介绍和网上资料的查询,这里就来给大家列举和大致 ...
- asp.net MVC 4.0 Model元数据回顾——HtmlHelper的ModelMetadata
模板方法包括Display/DisplayFor.Editor/EditorFor.DisplayForModel/EditForModel提供辅助生成Html的模型元数据信息 public stat ...
- [ASP.NET MVC]笔记(一)模型和HTML辅助方法
1.ModelState.IsValid 检验模型有效性 2.显示模型绑定(操作方法中没有参数): UpdateModel(album):模型绑定期间出错会抛出异常 TryUpdateModel ...
- ASP.NET MVC 3.0 Controller基础
ASP.NET MVC 3.0 Controller基础 1.Controller类与方法 Controller(控制器)是ASP.NET MVC的核心,负责处理浏览器请求,并作出响应.Cotro ...
- 返璞归真 asp.net mvc (7) - asp.net mvc 3.0 新特性之 Controller
原文:返璞归真 asp.net mvc (7) - asp.net mvc 3.0 新特性之 Controller [索引页][源码下载] 返璞归真 asp.net mvc (7) - asp.net ...
- 返璞归真 asp.net mvc (8) - asp.net mvc 3.0 新特性之 Model
原文:返璞归真 asp.net mvc (8) - asp.net mvc 3.0 新特性之 Model [索引页][源码下载] 返璞归真 asp.net mvc (8) - asp.net mvc ...
- ASP.NET MVC 4.0中选择Windows 验证默认出错拒绝访问的原因和解决方案
在VS 2012或者2013 中,根据模板创建一个ASP.NET MVC 4.0的应用程序,选择下面的模板 然后选择Intranet Application 不对源代码做任何修改,直接按下F5调试,会 ...
- 安装了VS2010 sp1 后再安装ASP.NET MVC 3.0的问题
安装了VS2010 sp1 后再安装ASP.NET MVC 3.0的问题(Final Result: Installation failed with error code: (0x80070643) ...
随机推荐
- memcache 在php中的用法
memcached 的安装方法详见我博客的另一个页面:http://www.cnblogs.com/chrdai/p/6656443.html 用法: 一.memcache 连接命令: 1.memca ...
- jd-gui的使用方法
java的反编译工具,简单使用: 打开文件.单击“file”从中选择“Open File ...“选项,弹出一个文件选择框,可以选择要打开的文件,或者直接单击文件夹图标,直接弹出文件选择框:从文件选择 ...
- EasyUI学习总结(六)——EasyUI布局
一.EasyUI布局介绍 easyUI布局容器包括东.西.南.北.中五个区域,其中中心面板是必须的,而东.西.南.北这四个面板是可选的,如果布局里面不需要东.西.南.北这四个面板,那么可以把相应的di ...
- Delphi 中big5 转 Unicode 函数
function Big5ToUnicode(str Char): widestring; var len: integer; begin len:=MultiByteToWideChar(,,PCh ...
- Amazon.com 美国亚马逊 直邮中国 手把手教程(转)
什么值得买已经发布2014最新版美亚直邮攻略 海淘攻略:美国亚马逊 直邮服务 手把手教程(2014最新版) ,调整幅度较大,值友们可以移步到新攻略中查看. 相比德国.英国亚马逊,美国亚马逊的大部分商品 ...
- Linux下RocketMQ环境的配置
RocketMQ是一款分布式消息系统,最初是由阿里巴巴消息中间件团队研发并大规模应用于生产系统,满足线上海量堆积的需求,在去年捐赠给Apache开源基金会,并列为孵化项目,今年成功的正式成为了apac ...
- js-BootstrapValidator简单使用
本例使用版本 <!-- 新 Bootstrap 核心 CSS 文件 --> <link href="http://cdn.static.runoob.com/libs/bo ...
- PHP中日志相关处理
内置函数: 1.error_log() ,第三个参数不能是绝对路径,必须是相对路径.写入文件: error_log("warn:\nthis is a warn!\n",3,&qu ...
- grid - 网格轨道最小和最大尺寸
可以通过minmax()函数来创建网格轨道的最小或最大尺寸. minmax()函数接受两个参数: 第一个参数定义网格轨道的最小值 第二个参数定义网格轨道的最大值 可以接受任何长度值,也接受auto值. ...
- iOS开发之Xcode9报错 Compiling IB documents for earlier than iOS7 is no longer supported.
升级到Xcode9时,最低的编译版本为iOS8,但是在使用一些SDK的时候就会报出Compiling IB documents for earlier than iOS7 is no longer s ...