亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > .NET > 正文

ASP.NET MVC中HtmlHelper控件7個大類中各個控件使用詳解

2024-07-10 13:30:03
字體:
來源:轉載
供稿:網友
本文主要介紹HtmlHelper類控件的使用方法,給初涉MVC的朋友一些幫助,有需要的朋友可以參考一下。
 

HtmlHelper類在命令System.Web.Mvc.Html之中,主要由7個靜態類組成,它們分別是FormExtensions類,InputExtensions類,LinkExtensions類,SelectExtensions類,TextExtensions類,ValidationExtensions類,RenderPartialExtensions類。

為了方便開發者使用HtmlHelper控件,在視圖ViewPage類中設置了一個屬性Html它就是HtmlHelper類型。

一.FormExtensions類

定義了3中類型的擴展方法BeginForm,BeginRouteForm,EndForm。

(1) BeginForm (實現表單定義的開始部分)

重載方法有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,IDictionary<string,object> htmlAttributes);

BeginForm(string actionName,string controllerName,object routeValues,FormMethod method,object htmlAttributes);

BeginForm(string actionName,string controllerName,RouteValueDictionary routeValues,FormMethod method,IDictionary<string,object> htmlAttributes);

對于第二個重載方法可以設置如下:

 

復制代碼代碼如下:

Html.BeginForm(new{action="action",controller="actroller",id="2"});

 

在上述代碼中,設置了路由值的一個實例化對象,輸出的HTML語句是:

 

復制代碼代碼如下:

<form action="actroller/action/2" method="post"/>

 

對于最后一個第十三個方法的最后一個參數是實例化對象設置相關屬性的值例如class,width等。

(2)BeginRouteForm (主要實現表單定義的開始部分,以路由的方法設置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的區別就在于第一個的action是action第二個的action是Home/action

(3)EndForm(實現表單的定義的結束部分)

 

復制代碼代碼如下:

Html.EndForm();

 

相當于</Form>

二.InputExtensions類有5種類型的擴展方法,可在視圖中設置checkBox,hidden,password,radioButton,textBox控件。

(1)CheckBox 實現復選框控件有6個重載方法

CheckBox(string name);

CheckBox(string name,bool isChecked);

CheckBox(string name,bool isChecked,object htmlAttributes);

CheckBox(string name,object htmlAttributes);

CheckBox(string name,Idictionary<string,object> htmlAttributes);

CheckBox(string name,bool isChecked,Idictionary<string,object> htmlAttributes);

設置復選框的實現代碼:

 

復制代碼代碼如下:

<%=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 表單中的隱藏數值,有4個重載方法。

Hidden(string name);

Hidden(string name,object value);

Hidden(string name,object value,object htmlAttributes);

Hidden(string name,object value,Idictionary<string,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,Idictionary<string,object> htmlAttributes);

eg:

 

復制代碼代碼如下:

Html.Password ("MyPwd");

對應輸出的Html語句如下:
復制代碼代碼如下:

<input id="MyPwd" name="MyPwd" type="password" />

 

--------------------------------------------------------------------------------------------

HTML擴展類的所有方法都有2個參數:

以textbox為例子
public static string TextBox( this HtmlHelper htmlHelper, string name, Object value, IDictionary<string, Object> htmlAttributes )
public static string TextBox( this HtmlHelper htmlHelper, string name, Object value, Object htmlAttributes )
這2個參數代表這個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" })%>

 

生成結果為:

 

復制代碼代碼如下:

<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("關于", "about", new { })%>

 

帶QueryString

 

復制代碼代碼如下:

<%=Html.RouteLink("關于", "about", new { page = 1 })%>
<%=Html.RouteLink("關于", "about", new { page = 1 }, new { id = "link1" })%>

 

生成結果:

 

復制代碼代碼如下:

<a href="/about">關于</a>
<a href="/about?page=1">關于</a>
<a href="/about?page=1" id="link1">關于</a>

 

3.Form 2種方法

 

復制代碼代碼如下:

<%using(Html.BeginForm("index","home",FormMethod.Post)){%>
<%} %>

 

 

復制代碼代碼如下:

<%Html.BeginForm("index", "home", FormMethod.Post);//注意這里沒有=輸出%>
<%Html.EndForm(); %>

 

生成結果:

 

復制代碼代碼如下:

<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;" })%>

 

生成結果:

 

復制代碼代碼如下:

<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)%>

 

生成結果:

 

復制代碼代碼如下:

<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" })%>

 

生成結果:

 

復制代碼代碼如下:

<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"])%>

 

生成結果:

 

復制代碼代碼如下:

<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" })%>

 

生成結果:

 

復制代碼代碼如下:

<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"); %> 

 

看清楚了沒有等號的。



發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
韩日精品中文字幕| 中文字幕免费国产精品| 久久久国产精品x99av| 91精品国产91久久久久久不卡| 在线观看国产精品日韩av| 亚洲精品影视在线观看| 久久天天躁日日躁| 国产精品丝袜高跟| 一区二区三区高清国产| 中文字幕欧美精品在线| 欧美专区在线视频| 在线成人激情黄色| 色婷婷综合久久久久中文字幕1| 欧美午夜激情在线| 日韩在线一区二区三区免费视频| 亚洲欧洲在线视频| 亚洲国产精品va在线| 欧美第一黄色网| 国产综合久久久久| 一区二区福利视频| 一区二区成人精品| 亚洲精品www久久久久久广东| 欧美一区二区三区图| 亚洲精品一区av在线播放| 色无极亚洲影院| 国产一区二区丝袜高跟鞋图片| 全球成人中文在线| 日韩成人在线视频网站| 亚洲自拍中文字幕| 国产日本欧美在线观看| 欧美成人精品h版在线观看| 色香阁99久久精品久久久| 亚洲精品一区av在线播放| www.亚洲免费视频| 另类少妇人与禽zozz0性伦| 97成人精品视频在线观看| 亚洲午夜av久久乱码| 国产成人午夜视频网址| 911国产网站尤物在线观看| 亚洲人成网在线播放| 日本国产欧美一区二区三区| 亚洲成人三级在线| 亚洲人永久免费| 欧美黑人极品猛少妇色xxxxx| 国产精品一区二区三区在线播放| 国产精品扒开腿做爽爽爽的视频| 国产成人一区二区在线| 日韩电影网在线| 亚洲一区二区国产| 97精品欧美一区二区三区| 色综合久久中文字幕综合网小说| 国产精品国产亚洲伊人久久| 亚洲成av人片在线观看香蕉| 国产精品亚洲视频在线观看| 4444欧美成人kkkk| 成人性生交大片免费观看嘿嘿视频| 亚洲第一天堂av| 亚洲精品小视频在线观看| 日韩国产中文字幕| 一本一道久久a久久精品逆3p| 亚洲成人精品久久| 丁香五六月婷婷久久激情| 欧美日韩福利视频| 国产成人精品av在线| 深夜精品寂寞黄网站在线观看| 91沈先生在线观看| 久久久久久亚洲精品| 欧美午夜激情小视频| 在线观看亚洲视频| 国产精品色视频| 精品久久久国产精品999| 亚洲一区av在线播放| 欧美成年人在线观看| 日韩黄在线观看| 国产精品高潮粉嫩av| 主播福利视频一区| 久久精品免费播放| 国产一区二区三区三区在线观看| 国产香蕉精品视频一区二区三区| 日本精品性网站在线观看| 美女性感视频久久久| 久久全球大尺度高清视频| 影音先锋欧美在线资源| 国产精品久久久久久久久久ktv| 国产精品91免费在线| 日韩av手机在线| 欧美日韩一区二区三区在线免费观看| 国产欧美在线播放| 亚洲成人性视频| 国产精品专区h在线观看| 狠狠躁夜夜躁人人爽超碰91| 欧美性xxxx极品高清hd直播| 国产精品久久久久久久久免费| 欧美国产日韩一区| 日韩电影免费观看在线观看| 国产日本欧美一区二区三区在线| 久久99精品久久久久久青青91| 久久影视电视剧凤归四时歌| 久久人人爽人人| 亚洲国产另类久久精品| 国产精品自产拍在线观看中文| 91经典在线视频| 日韩毛片中文字幕| 成人在线视频福利| 亚洲精品视频在线观看视频| 日韩中文字幕精品| 日韩美女视频免费在线观看| 欧美极品少妇xxxxⅹ裸体艺术| 欧美又大又粗又长| 国产精品一区二区三| 欧美午夜宅男影院在线观看| 中文字幕国产精品久久| 九色成人免费视频| 国产欧美日韩综合精品| 欧美精品在线免费| 欧美一级大胆视频| 日韩在线视频观看正片免费网站| 日韩资源在线观看| 国产91|九色| 日本中文字幕久久看| 亚洲小视频在线观看| 国产丝袜一区视频在线观看| 日韩在线免费高清视频| 黄色91在线观看| 精品久久久久久久久久久久久| 欧美日韩加勒比精品一区| 欧美高清视频在线播放| 最近2019年好看中文字幕视频| 日本高清视频一区| 中文字幕在线观看亚洲| 久久影院免费观看| 欧美日韩激情视频| 欧美在线一级va免费观看| 亚洲国产小视频在线观看| 欧美极品少妇xxxxⅹ裸体艺术| 亚洲日本中文字幕| 中文字幕在线日韩| 欧美性生活大片免费观看网址| 久热爱精品视频线路一| 国产精品自拍网| 国产美女91呻吟求| 国产美女久久精品香蕉69| 日本在线观看天堂男亚洲| www.xxxx欧美| 国产精品久久国产精品99gif| 成人黄色网免费| 91高清视频在线免费观看| 日韩欧美一区二区三区| 97超视频免费观看| 亚洲wwwav| 日韩精品在线观看网站| 久久精品国产91精品亚洲| 中文日韩电影网站| 国产成人精品视频在线| 久久成年人视频| 亚洲欧美制服第一页| 九九热精品视频| 日韩av综合网站| 欧美亚洲日本黄色| 欧美夫妻性视频| 亚洲男人天堂2019| 亚洲精品自拍偷拍| 日韩欧美在线视频观看| 81精品国产乱码久久久久久|