欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2016年03月26日 17:09:16   作者:only one minmin  
本文主要介紹HtmlHelper類控件的使用方法,給初涉MVC的朋友一些幫助,有需要的朋友可以參考一下。

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,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"/>

對于最后一個第十三個方法的最后一個參數(shù)是實例化對象設置相關屬性的值例如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)表單的定義的結束部分)

復制代碼 代碼如下:

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,Idictionary<string,object> htmlAttributes);

CheckBox(string name,bool isChecked,Idictionary<string,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,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個參數(shù):

以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個參數(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" })%>

生成結果為:

復制代碼 代碼如下:

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

看清楚了沒有等號的。

相關文章

  • WPF路由事件中的三種策略介紹

    WPF路由事件中的三種策略介紹

    這篇文章介紹了WPF路由事件中的三種策略,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-02-02
  • .Net MVC實現(xiàn)長輪詢

    .Net MVC實現(xiàn)長輪詢

    這篇文章主要為大家詳細介紹了.Net MVC實現(xiàn)長輪詢的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • CefSharp v62修改方法(支持.net4.0)

    CefSharp v62修改方法(支持.net4.0)

    下面小編就為大家分享一篇CefSharp v62修改方法(支持.net4.0),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • ASP.NET 動態(tài)寫入服務器端控件

    ASP.NET 動態(tài)寫入服務器端控件

    使用Asp.net進行開發(fā)時,因為某些需求原因,需要在頁面中動態(tài)添加控件。當然,這些控件可以是普通的html標簽,也可以是Asp.net獨有的服務器端控件。
    2009-04-04
  • .NET連接池的問題詳解

    .NET連接池的問題詳解

    這篇文章主要介紹了.NET連接池的問題詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12
  • 使用HttpClient增刪改查ASP.NET Web API服務

    使用HttpClient增刪改查ASP.NET Web API服務

    這篇文章介紹了使用HttpClient增刪改查ASP.NET Web API服務的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-10-10
  • 編譯?dotnet和aspnetcore?源代碼詳情

    編譯?dotnet和aspnetcore?源代碼詳情

    這篇文章主要介紹了編譯?dotnet和aspnetcore?源代碼詳情,圍繞主題相關資料展開展開全文內容,具有一定的參考價值需要的小伙伴可以參考一下
    2022-03-03
  • asp.net生成靜態(tài)頁并分頁+ubb

    asp.net生成靜態(tài)頁并分頁+ubb

    編程思路生成靜態(tài)頁其實只有內容部分是需要分頁的,生成靜態(tài)頁并分頁的步驟是在textarea或者在線編輯器中,需要分頁的地方就插入一個[ page ]
    2008-10-10
  • 詳解ASP.NET中Session的用法

    詳解ASP.NET中Session的用法

    我們可以使用 Session 對象存儲特定的用戶會話所需的信息,這篇文章就為大家詳細介紹了ASP.NET中Session的用法,感興趣的小伙伴們可以參考一下
    2016-05-05
  • ASP.NET Core中實現(xiàn)用戶登錄驗證的最低配置示例代碼

    ASP.NET Core中實現(xiàn)用戶登錄驗證的最低配置示例代碼

    最近工作中遇到一個需求,需要在ASP.NET Core中來實現(xiàn)一個基礎的身份認證,下面這篇文章主要給大家介紹了關于ASP.NET Core中實現(xiàn)用戶登錄驗證的最低配置的相關資料,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-10-10

最新評論