HtmlHelper類在命令System.Web.Mvc.Html之中,主要由7個靜態(tài)類組成,它們分別是FormExtensions類,InputExtensions類,LinkExtensions類,SelectExtensions類,TextExtensions類,ValidationExtensions類,RenderPartialExtensions類。
為了方便開發(fā)者使用HtmlHelper控件,在視圖ViewPage類中設置了一個屬性Html它就是HtmlHelper類型。
一.FormExtensions類
定義了3中類型的擴展方法BeginForm,BeginRouteForm,EndForm。
(1) BeginForm (實現(xiàn)表單定義的開始部分)
重載方法有13個:
BeginForm();
BeginForm(Object routeValues);
BeginForm(RouteValueDictionary routeValues);
BeginForm(string actionName,string controllerName);
BeginForm(string actionName,string controllerName,object routeValues);
BeginForm(string actionName,string controllerName,RouteValueDictionary routeValues);
BeginForm(string actionName,string controllerName,FormMethod method);
BeginForm(string actionName,string controllerName,object routeValues,FormMethod method);
BeginForm(string actionName,string controllerName,RouteValueDictionary routeVaues,FormMethod method);
BeginForm(string actionName,string controllerName,FormMethod method,object htmlAttributes);
BeginForm(string actionName,string controllerName,FormMethod method,IDictionarystring,object> htmlAttributes);
BeginForm(string actionName,string controllerName,object routeValues,FormMethod method,object htmlAttributes);
BeginForm(string actionName,string controllerName,RouteValueDictionary routeValues,FormMethod method,IDictionarystring,object> htmlAttributes);
對于第二個重載方法可以設置如下:
復制代碼 代碼如下:
Html.BeginForm(new{action="action",controller="actroller",id="2"});
在上述代碼中,設置了路由值的一個實例化對象,輸出的HTML語句是:
復制代碼 代碼如下:
form action="actroller/action/2" method="post"/>
對于最后一個第十三個方法的最后一個參數(shù)是實例化對象設置相關(guān)屬性的值例如class,width等。
(2)BeginRouteForm (主要實現(xiàn)表單定義的開始部分,以路由的方法設置action的值)
有12個重載方法:
BeginRouteForm(object routeValues);
BeginRouteForm(RouteValueDictionary routeValues);
BeginRouteForm(string routeName);
BeginRouteForm(string routeName,object routeValues);
BeginRouteForm(string routeName,RouteValueDictionary routeValues);
BeginRouteForm(string routeName,FormMethod method);
BeginRouteForm(string routeName,object routeValues,FormMethod method);
……
對于第一個重載方法:
復制代碼 代碼如下:
Html.BeginRouteForm(new {action="action"});
復制代碼 代碼如下:
form action="Home/action" method="post"/>Home是頁面所在的目錄
BeginForm與BeginRouteForm的區(qū)別就在于第一個的action是action第二個的action是Home/action
(3)EndForm(實現(xiàn)表單的定義的結(jié)束部分)
復制代碼 代碼如下:
Html.EndForm();
相當于/Form>
二.InputExtensions類有5種類型的擴展方法,可在視圖中設置checkBox,hidden,password,radioButton,textBox控件。
(1)CheckBox 實現(xiàn)復選框控件有6個重載方法
CheckBox(string name);
CheckBox(string name,bool isChecked);
CheckBox(string name,bool isChecked,object htmlAttributes);
CheckBox(string name,object htmlAttributes);
CheckBox(string name,Idictionarystring,object> htmlAttributes);
CheckBox(string name,bool isChecked,Idictionarystring,object> htmlAttributes);
設置復選框的實現(xiàn)代碼:
復制代碼 代碼如下:
%=Html.BeginForm("CheckBox","Home") %>
fieldset>
legend>設置字體:/lengend>
%=Html.CheckBox("MyCheckBox1",true,new{id="checkBox1"})%>
label for="checkBox1">黑體/label>
%=Html.CheckBox("MyCheckBox2",false,new{id="checkBox2"})%>
label for="checkBox1">斜體/label>
br/>br/>
input type="submit" value="Submit"/>
/fieldset>
%Html.EndForm();%>
運行上述代碼,上述復選框的設置代碼對應的HTML語句:
復制代碼 代碼如下:
input checked="checked" id="checkBox1" name="MyCheckBox1" type="CheckBox" value="true"/>
input name="MyCheckBox1" type="hidden" value="false"/>
input id="checkBox2" name="MyCheckBox2" type="CheckBox" value="false"/>
input name="MyCheckBox2" type="hidden" value="false"/>
在后臺檢索checkBox
復制代碼 代碼如下:
public ActionResult CheckBox (FormCollection formCollection)
{
bool MyCheckBox1=formCollection[0].Contains("true");//檢索第一個復選框是否被選中
bool MyCheckBox2=formCollection["MyCheckBox2"].Contains("true");//檢索名字是MyCheckBox2的復選框是否倍選中
ViewData["CheckBox1"]=MyCheckBox1;
ViewData["CheckBox2"]=MyCheckBox2;
return View();
}
(2)Hidden 表單中的隱藏數(shù)值,有4個重載方法。
Hidden(string name);
Hidden(string name,object value);
Hidden(string name,object value,object htmlAttributes);
Hidden(string name,object value,Idictionarystring,object> htmlAttributes);
eg:
復制代碼 代碼如下:
Html.Hidden("testName");
對應輸出的Html語句如下:
復制代碼 代碼如下:
input id="testName" name="testName" type="hidden" value=""/>
(3)Password 主要是輸入密碼的文本框,有4個重載方法。
Hidden(string name);
Password (string name,object value);
Password (string name,object value,object htmlAttributes);
Password (string name,object value,Idictionarystring,object> htmlAttributes);
eg:
復制代碼 代碼如下:
Html.Password ("MyPwd");
對應輸出的Html語句如下:
復制代碼 代碼如下:
input id="MyPwd" name="MyPwd" type="password" />
--------------------------------------------------------------------------------------------
HTML擴展類的所有方法都有2個參數(shù):
以textbox為例子
public static string TextBox( this HtmlHelper htmlHelper, string name, Object value, IDictionarystring, Object> htmlAttributes )
public static string TextBox( this HtmlHelper htmlHelper, string name, Object value, Object htmlAttributes )
這2個參數(shù)代表這個html標簽的屬性集合。使用方法如下。
1.ActionLink
復制代碼 代碼如下:
%=Html.ActionLink("這是一個連接", "Index", "Home")%>
帶有QueryString的寫法
復制代碼 代碼如下:
%=Html.ActionLink("這是一個連接", "Index", "Home", new { page=1 },null)%>
%=Html.ActionLink("這是一個連接", "Index", new { page=1 })%>
有其它Html屬性的寫法
復制代碼 代碼如下:
%=Html.ActionLink("這是一個連接", "Index", "Home", new { id="link1" })%>
%=Html.ActionLink("這是一個連接", "Index",null, new { id="link1" })%>
QueryString與Html屬性同時存在
復制代碼 代碼如下:
%=Html.ActionLink("這是一個連接", "Index", "Home", new { page = 1 }, new { id = "link1" })%>
%=Html.ActionLink("這是一個連接", "Index" , new { page = 1 }, new { id = "link1" })%>
生成結(jié)果為:
復制代碼 代碼如下:
a href="/">這是一個連接/a>
帶有QueryString的寫法
復制代碼 代碼如下:
a href="/?page=1">這是一個連接/a>
a href="/?page=1">這是一個連接/a>
有其它Html屬性的寫法
復制代碼 代碼如下:
a href="/?Length=4" id="link1">這是一個連接/a>
a href="/" id="link1">這是一個連接/a>
QueryString與Html屬性同時存在
復制代碼 代碼如下:
a href="/?page=1" id="link1">這是一個連接/a>
a href="/?page=1" id="link1">這是一個連接/a>
2.RouteLink
跟ActionLink在功能上一樣。
復制代碼 代碼如下:
%=Html.RouteLink("關(guān)于", "about", new { })%>
帶QueryString
復制代碼 代碼如下:
%=Html.RouteLink("關(guān)于", "about", new { page = 1 })%>
%=Html.RouteLink("關(guān)于", "about", new { page = 1 }, new { id = "link1" })%>
生成結(jié)果:
復制代碼 代碼如下:
a href="/about">關(guān)于/a>
a href="/about?page=1">關(guān)于/a>
a href="/about?page=1" id="link1">關(guān)于/a>
3.Form 2種方法
復制代碼 代碼如下:
%using(Html.BeginForm("index","home",FormMethod.Post)){%>
%} %>
復制代碼 代碼如下:
%Html.BeginForm("index", "home", FormMethod.Post);//注意這里沒有=輸出%>
%Html.EndForm(); %>
生成結(jié)果:
復制代碼 代碼如下:
form action="/home/index" method="post">/form>
4.TextBox
復制代碼 代碼如下:
%=Html.TextBox("input1") %>
%=Html.TextBox("input2",Model.CategoryName,new{ @style = "width:300px;" }) %>
%=Html.TextBox("input3", ViewData["Name"],new{ @style = "width:300px;" }) %>
%=Html.TextBoxFor(a => a.CategoryName, new { @style = "width:300px;" })%>
生成結(jié)果:
復制代碼 代碼如下:
input id="input1" name="input1" type="text" value="" />
input id="input2" name="input2" style="width:300px;" type="text" value="Beverages" />
input id="input3" name="input3" style="width:300px;" type="text" value="" />
input id="CategoryName" name="CategoryName" style="width:300px;" type="text" value="Beverages" />
5.TextArea
復制代碼 代碼如下:
%=Html.TextArea("input5", Model.CategoryName, 3, 9,null)%>
%=Html.TextAreaFor(a => a.CategoryName, 3, 3, null)%>
生成結(jié)果:
復制代碼 代碼如下:
textarea cols="9" id="input5" name="input5" rows="3">Beverages/textarea>
textarea cols="3" id="CategoryName" name="CategoryName" rows="3">Beverages/textarea>
6.CheckBox
復制代碼 代碼如下:
%=Html.CheckBox("chk1",true) %>
%=Html.CheckBox("chk1", new { @class="checkBox"}) %>
%=Html.CheckBoxFor(a =>a.IsVaild, new { @class = "checkBox" })%>
生成結(jié)果:
復制代碼 代碼如下:
input checked="checked" id="chk1" name="chk1" type="checkbox" value="true" />input name="chk1" type="hidden" value="false" />
input class="checkBox" id="chk1" name="chk1" type="checkbox" value="true" />input name="chk1" type="hidden" value="false" />
input checked="checked" class="checkBox" id="IsVaild" name="IsVaild" type="checkbox" value="true" />input name="IsVaild" type="hidden" value="false" />
7.ListBox
復制代碼 代碼如下:
%=Html.ListBox("lstBox1",(SelectList)ViewData["Categories"])%>
%=Html.ListBoxFor(a => a.CategoryName, (SelectList)ViewData["Categories"])%>
生成結(jié)果:
復制代碼 代碼如下:
select id="lstBox1" multiple="multiple" name="lstBox1">
option value="1">Beverages/option>
option value="2">Condiments/option>
option selected="selected" value="3">Confections/option>
option value="4">Dairy Products/option>
option value="5">Grains/Cereals/option>
option value="6">Meat/Poultry/option>
option value="7">Produce/option>
option value="8">Seafood/option>
/select>
select id="CategoryName" multiple="multiple" name="CategoryName">
option value="1">Beverages/option>
option value="2">Condiments/option>
option value="3">Confections/option>
option value="4">Dairy Products/option>
option value="5">Grains/Cereals/option>
option value="6">Meat/Poultry/option>
option value="7">Produce/option>
option value="8">Seafood/option>
/select>
8.DropDownList
復制代碼 代碼如下:
%= Html.DropDownList("ddl1", (SelectList)ViewData["Categories"], "--Select One--")%>
%=Html.DropDownListFor(a => a.CategoryName, (SelectList)ViewData["Categories"], "--Select One--", new { @class = "dropdownlist" })%>
生成結(jié)果:
復制代碼 代碼如下:
select id="ddl1" name="ddl1">
option value="">--Select One--/option>
option value="1">Beverages/option>
option value="2">Condiments/option>
option selected="selected" value="3">Confections/option>
option value="4">Dairy Products/option>
option value="5">Grains/Cereals/option>
option value="6">Meat/Poultry/option>
option value="7">Produce/option>
option value="8">Seafood/option>
/select>
select class="dropdownlist" id="CategoryName" name="CategoryName">
option value="">--Select One--/option>
option value="1">Beverages/option>
option value="2">Condiments/option>
option value="3">Confections/option>
option value="4">Dairy Products/option>
option value="5">Grains/Cereals/option>
option value="6">Meat/Poultry/option>
option value="7">Produce/option>
option value="8">Seafood/option>
/select>
9.Partial 視圖模板
webform里叫自定義控件。功能都是為了復用。但使用上自定義控件真的很難用好。
復制代碼 代碼如下:
% Html.RenderPartial("DinnerForm"); %>
看清楚了沒有等號的。
您可能感興趣的文章:- ASP.NET MVC4 HtmlHelper擴展類,實現(xiàn)分頁功能
- ASP.NET MVC HtmlHelper如何擴展
- Java簡單實現(xiàn)SpringMVC+MyBatis分頁插件
- ASP.NET MVC 5使用X.PagedList.Mvc進行分頁教程(PagedList.Mvc)
- MVC+jQuery.Ajax異步實現(xiàn)增刪改查和分頁
- MVC分頁之MvcPager使用詳解
- 超好用輕量級MVC分頁控件JPager.Net
- ASP.NET MVC分頁和排序功能實現(xiàn)
- MVC HtmlHelper擴展類(PagingHelper)實現(xiàn)分頁功能