ASP.NET?Core?MVC中Form?Tag?Helpers用法介紹
簡介
我們已經(jīng)介紹過Tag Helpers以及一些最常用的Tag Helpers,也談到了緩存Tag Helpers。在這篇文章中,我們將討論表單Tag Helpers。
HTML或Web表單通過使用各種HTML元素用于收集來自用戶的輸入,如輸入框、復(fù)選框、單選按鈕、下拉列表等。使用 <form> 元素時,我們通常使用POST請求。雖然也可以使用GET請求,不過GET請求建議提交于少量、非敏感的數(shù)據(jù)來獲取數(shù)據(jù)。
ASP.NET Core MVC提供了一些Form Tag Helpers,讓我們看看最重要的是什么。
Form Tag Helper
當我們使用<form>元素時,ASP.NET Core MVC會自動添加防御CSRF攻擊保護措施;它通過生成隱藏的請求驗證令牌以防止CSRF攻擊。
看一個簡單的例子:
此代碼輸出的界面如下:
然而,這并不是全部,在幕后發(fā)生了什么:
請注意在HTTP Post操作方式中,RequestVerificationToken 與內(nèi)置的[ValidateAntiForgeryToken]
屬性一起工作,同時,該請求方法會被標記為post方式。
Form Tag Helper的還提供了asp-route-{ParameterName}屬性,其中參數(shù)名稱為被添加到路由的值;并且還提供了@Html.BeginForm
和@Html.BeginRouteForm
另一種清晰的替代方式。
如果我們添加一個自定義路由:
并將表單修改為如下:
我們得到以下HTML:
它將執(zhí)行與剛才指定的 controller 和 action 方法。
這是使用舊的HTML Helpers語法:
@using (Html.BeginForm("Edit", "Categories")) { }
新的語法是:
<form asp-action="Edit" asp-controller="Categories">{ }
第一個可能看起來更短更好,但第二個更自然,對于設(shè)計師或一名JS開發(fā)人員來說,在使用Angular、React的過程中,這將會更加自然。
Input Tag Helper
這一個很簡單,它是@Html.EditorFor(m => m.Name)
的替代方式。
假設(shè)我們有一個具有 Name 屬性的視圖模型:
<input asp-for="Name" />`
會產(chǎn)生如下代碼:
<input type="text" id="Name" name="Name" />
Label Tag Helper
這一個也很簡單,它是@Html.LabelFor(m => m.Name)
的替代方式。
它與輸入框Tag Helper配合使用:
<input asp-for="Name" /> <label asp-for="Name" />
與其它一樣,也具有智能感知功能,一旦您開始鍵入,就會檢測屬性的名稱:
如果我們將 Display 特性應(yīng)用于 Name 屬性:
這是我們將獲得的HTML內(nèi)容:
<label for="Name">Category Name</label>
TextArea Tag Helper
這一個非常類似于Input Tag Helper:
以下Razor代碼:
<textarea asp-for="Name"></textarea>`
我們將得到以下輸出:
Validation Message Tag Helper
我們使用Validation Tag Helper為我們的視圖模型的屬性顯示驗證消息,使用方式也很簡單:
<span asp-validation-for="Name"></span>
我們得到的HTML:
<span class="field-validation-valid" data-valmsg-for="Name" data-valmsg-replace="true"></span>
到此這篇關(guān)于ASP.NET Core MVC中Form Tag Helpers用法的文章就介紹到這了。希望對大家的學(xué)習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
讓Silverlight 2.0動畫動起來Making Silverlight 2.0 animation Start(
Microsoft Expression Blend 2 制作動畫個人感覺倒像3DMAX 可以自動捕捉關(guān)鍵幀2008-11-11Asp.Net 無刷新文件上傳并顯示進度條的實現(xiàn)方法及思路
這篇文章詳細介紹了無刷新文件上傳并顯示進度條的思路和代碼,有需要的朋友可以參考一下2013-06-06Entity Framework使用Code First模式管理數(shù)據(jù)庫
本文詳細講解了Entity Framework使用Code First模式管理數(shù)據(jù)庫的方法,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03IIS實現(xiàn)反向代理時Cookie域的設(shè)置方法
這篇文章主要給大家介紹了關(guān)于IIS實現(xiàn)反向代理時Cookie域的設(shè)置方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧。2018-04-04Entity Framework Core中執(zhí)行SQL語句和存儲過程的方法介紹
這篇文章介紹了Entity Framework Core中執(zhí)行SQL語句和存儲過程的方法,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-02-02ASP.Net Core(C#)創(chuàng)建Web站點的實現(xiàn)
本文主要介紹了ASP.Net Core(C#)創(chuàng)建Web站點的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧2023-07-07讀取XML并綁定至RadioButtonList實現(xiàn)思路及演示動畫
讀取XML的文檔,可以使用System.Data.DataSet類別中的ReadXml()方法,在aspx網(wǎng)頁上拉一個RadioButtonList控件,用來顯示XML的數(shù)據(jù),接下來,用DataSet去讀取剛才寫好的獲取XML文件的屬性,即可完成2013-01-01ASP.NET中GridView和Repeater重復(fù)數(shù)據(jù)如何合并
這篇文章主要介紹了ASP.NET中GridView和Repeater重復(fù)數(shù)據(jù)合并的方法,感興趣的小伙伴們可以參考一下2016-08-08