濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > ASP.NET MVC中HtmlHelper控件7個(gè)大類中各個(gè)控件使用詳解

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

熱門標(biāo)簽:地圖定位圖標(biāo)標(biāo)注 地圖標(biāo)注的公司有哪些 遂寧市地圖標(biāo)注app 代理接電話機(jī)器人如何取消 塔城代理外呼系統(tǒng) 地圖標(biāo)注專業(yè)團(tuán)隊(duì) 天心智能電銷機(jī)器人 400電話辦理哪家性價(jià)比高 濮陽(yáng)外呼電銷系統(tǒng)怎么樣

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

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

一.FormExtensions類

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

(1) BeginForm (實(shí)現(xiàn)表單定義的開始部分)

重載方法有13個(gè):

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

對(duì)于第二個(gè)重載方法可以設(shè)置如下:

復(fù)制代碼 代碼如下:

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

在上述代碼中,設(shè)置了路由值的一個(gè)實(shí)例化對(duì)象,輸出的HTML語(yǔ)句是:

復(fù)制代碼 代碼如下:

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

對(duì)于最后一個(gè)第十三個(gè)方法的最后一個(gè)參數(shù)是實(shí)例化對(duì)象設(shè)置相關(guān)屬性的值例如class,width等。

(2)BeginRouteForm (主要實(shí)現(xiàn)表單定義的開始部分,以路由的方法設(shè)置action的值)

有12個(gè)重載方法:

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

……

對(duì)于第一個(gè)重載方法:

復(fù)制代碼 代碼如下:

Html.BeginRouteForm(new {action="action"});

復(fù)制代碼 代碼如下:

form action="Home/action" method="post"/>Home是頁(yè)面所在的目錄

BeginForm與BeginRouteForm的區(qū)別就在于第一個(gè)的action是action第二個(gè)的action是Home/action

(3)EndForm(實(shí)現(xiàn)表單的定義的結(jié)束部分)

復(fù)制代碼 代碼如下:

Html.EndForm();

相當(dāng)于/Form>

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

(1)CheckBox 實(shí)現(xiàn)復(fù)選框控件有6個(gè)重載方法

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

設(shè)置復(fù)選框的實(shí)現(xiàn)代碼:

復(fù)制代碼 代碼如下:

%=Html.BeginForm("CheckBox","Home") %>
fieldset>
legend>設(shè)置字體:/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();%>

運(yùn)行上述代碼,上述復(fù)選框的設(shè)置代碼對(duì)應(yīng)的HTML語(yǔ)句:

復(fù)制代碼 代碼如下:

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

在后臺(tái)檢索checkBox

復(fù)制代碼 代碼如下:

public ActionResult CheckBox (FormCollection formCollection)
{
 bool MyCheckBox1=formCollection[0].Contains("true");//檢索第一個(gè)復(fù)選框是否被選中
 bool MyCheckBox2=formCollection["MyCheckBox2"].Contains("true");//檢索名字是MyCheckBox2的復(fù)選框是否倍選中
 ViewData["CheckBox1"]=MyCheckBox1;
 ViewData["CheckBox2"]=MyCheckBox2;
 return View();
}

(2)Hidden 表單中的隱藏?cái)?shù)值,有4個(gè)重載方法。

Hidden(string name);

Hidden(string name,object value);

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

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

eg:

復(fù)制代碼 代碼如下:

Html.Hidden("testName");

對(duì)應(yīng)輸出的Html語(yǔ)句如下:

復(fù)制代碼 代碼如下:

input id="testName" name="testName" type="hidden" value=""/>

(3)Password 主要是輸入密碼的文本框,有4個(gè)重載方法。

Hidden(string name);

Password (string name,object value);

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

Password (string name,object value,Idictionarystring,object> htmlAttributes);

eg:

復(fù)制代碼 代碼如下:

Html.Password ("MyPwd");

對(duì)應(yīng)輸出的Html語(yǔ)句如下:
復(fù)制代碼 代碼如下:

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

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

HTML擴(kuò)展類的所有方法都有2個(gè)參數(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個(gè)參數(shù)代表這個(gè)html標(biāo)簽的屬性集合。使用方法如下。

1.ActionLink

復(fù)制代碼 代碼如下:

%=Html.ActionLink("這是一個(gè)連接", "Index", "Home")%>

帶有QueryString的寫法

復(fù)制代碼 代碼如下:

%=Html.ActionLink("這是一個(gè)連接", "Index", "Home", new { page=1 },null)%>
%=Html.ActionLink("這是一個(gè)連接", "Index", new { page=1 })%>

有其它Html屬性的寫法

復(fù)制代碼 代碼如下:

%=Html.ActionLink("這是一個(gè)連接", "Index", "Home", new { id="link1" })%>
%=Html.ActionLink("這是一個(gè)連接", "Index",null, new { id="link1" })%>

QueryString與Html屬性同時(shí)存在

復(fù)制代碼 代碼如下:

%=Html.ActionLink("這是一個(gè)連接", "Index", "Home", new { page = 1 }, new { id = "link1" })%>
%=Html.ActionLink("這是一個(gè)連接", "Index" , new { page = 1 }, new { id = "link1" })%>

生成結(jié)果為:

復(fù)制代碼 代碼如下:

a href="/">這是一個(gè)連接/a>

帶有QueryString的寫法

復(fù)制代碼 代碼如下:

a href="/?page=1">這是一個(gè)連接/a>
a href="/?page=1">這是一個(gè)連接/a>

有其它Html屬性的寫法

復(fù)制代碼 代碼如下:

a href="/?Length=4" id="link1">這是一個(gè)連接/a>
a href="/" id="link1">這是一個(gè)連接/a>

QueryString與Html屬性同時(shí)存在

復(fù)制代碼 代碼如下:

a href="/?page=1" id="link1">這是一個(gè)連接/a>
a href="/?page=1" id="link1">這是一個(gè)連接/a>

2.RouteLink

跟ActionLink在功能上一樣。

復(fù)制代碼 代碼如下:

%=Html.RouteLink("關(guān)于", "about", new { })%>

帶QueryString

復(fù)制代碼 代碼如下:

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

生成結(jié)果:

復(fù)制代碼 代碼如下:

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種方法

復(fù)制代碼 代碼如下:

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

復(fù)制代碼 代碼如下:

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

生成結(jié)果:

復(fù)制代碼 代碼如下:

form action="/home/index" method="post">/form>

4.TextBox

復(fù)制代碼 代碼如下:

%=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é)果:

復(fù)制代碼 代碼如下:

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

復(fù)制代碼 代碼如下:

%=Html.TextArea("input5", Model.CategoryName, 3, 9,null)%>
%=Html.TextAreaFor(a => a.CategoryName, 3, 3, null)%>

生成結(jié)果:

復(fù)制代碼 代碼如下:

textarea cols="9" id="input5" name="input5" rows="3">Beverages/textarea>
textarea cols="3" id="CategoryName" name="CategoryName" rows="3">Beverages/textarea>

6.CheckBox

復(fù)制代碼 代碼如下:

%=Html.CheckBox("chk1",true) %>
%=Html.CheckBox("chk1", new { @class="checkBox"}) %>
%=Html.CheckBoxFor(a =>a.IsVaild, new { @class = "checkBox" })%>

生成結(jié)果:

復(fù)制代碼 代碼如下:

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

復(fù)制代碼 代碼如下:

%=Html.ListBox("lstBox1",(SelectList)ViewData["Categories"])%>
%=Html.ListBoxFor(a => a.CategoryName, (SelectList)ViewData["Categories"])%>

生成結(jié)果:

復(fù)制代碼 代碼如下:

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

復(fù)制代碼 代碼如下:

%= Html.DropDownList("ddl1", (SelectList)ViewData["Categories"], "--Select One--")%>
%=Html.DropDownListFor(a => a.CategoryName, (SelectList)ViewData["Categories"], "--Select One--", new { @class = "dropdownlist" })%>

生成結(jié)果:

復(fù)制代碼 代碼如下:

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里叫自定義控件。功能都是為了復(fù)用。但使用上自定義控件真的很難用好。

復(fù)制代碼 代碼如下:

% Html.RenderPartial("DinnerForm"); %>

看清楚了沒有等號(hào)的。

您可能感興趣的文章:
  • ASP.NET MVC4 HtmlHelper擴(kuò)展類,實(shí)現(xiàn)分頁(yè)功能
  • ASP.NET MVC HtmlHelper如何擴(kuò)展
  • Java簡(jiǎn)單實(shí)現(xiàn)SpringMVC+MyBatis分頁(yè)插件
  • ASP.NET MVC 5使用X.PagedList.Mvc進(jìn)行分頁(yè)教程(PagedList.Mvc)
  • MVC+jQuery.Ajax異步實(shí)現(xiàn)增刪改查和分頁(yè)
  • MVC分頁(yè)之MvcPager使用詳解
  • 超好用輕量級(jí)MVC分頁(yè)控件JPager.Net
  • ASP.NET MVC分頁(yè)和排序功能實(shí)現(xiàn)
  • MVC HtmlHelper擴(kuò)展類(PagingHelper)實(shí)現(xiàn)分頁(yè)功能

標(biāo)簽:本溪 麗江 婁底 汕頭 宜春 重慶 吉林 河南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ASP.NET MVC中HtmlHelper控件7個(gè)大類中各個(gè)控件使用詳解》,本文關(guān)鍵詞  ASP.NET,MVC,中,HtmlHelper,控件,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《ASP.NET MVC中HtmlHelper控件7個(gè)大類中各個(gè)控件使用詳解》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于ASP.NET MVC中HtmlHelper控件7個(gè)大類中各個(gè)控件使用詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    双峰县| 清远市| 陈巴尔虎旗| 潼南县| 奉化市| 萨迦县| 哈尔滨市| 温泉县| 防城港市| 定安县| 岗巴县| 山东省| 德化县| 巴彦县| 台安县| 巧家县| 浮梁县| 新巴尔虎左旗| 清镇市| 盐津县| 徐水县| 沛县| 谷城县| 砀山县| 许昌县| 永清县| 唐海县| 蓝山县| 台北县| 荥阳市| 长丰县| 建瓯市| 苏尼特左旗| 舒兰市| 涟源市| 大兴区| 都江堰市| 苗栗市| 城步| 阿城市| 德清县|