ASP.NET MVC實現(xiàn)多個按鈕提交的方法
有時候會遇到這種情況:在一個表單上需要多個按鈕來完成不同的功能,比如一個簡單的審批功能。
如果是用webform那不需要討論,但asp.net mvc中一個表單只能提交到一個Action處理,相對比較麻煩點。
方法一:使用客戶端腳本
比如我們在View中這樣寫:
<inputtype="submit"value="審核通過"onclick='this.form.action="<%=Url.Action("Action1")%>/> <inputtype="submit"value="審核不通過"onclick='this.form.action="<%=Url.Action("Action2")%> /> <inputtype="submit"value="返回"onclick='this.form.action="<%=Url.Action("Action3")%>" />
在點擊提交按鈕時,先改變Form的action屬性,使表單提交到按鈕相應的action處理。
但有的時候,可能Action1和2的邏輯非常類似,也許只是將某個字段的值置為1或者0,那么分開到二個action中又顯得有點多余了。
方法二:在Action中判斷通過哪個按鈕提交
在View中,我們不用任何客戶端腳本處理,給每個提交按鈕加好name屬性:
<input type="submit" value="審核通過" name="action" /> <input type="submit" value="審核不通過" name="action"/> <input type="submit" value="返回" name="action"/>
然后在控制器中判斷:
[HttpPost] public ActionResult Index(string action /* 其它參數(shù)*/) { if (action=="審核通過") { // } else if (action=="審核不通過") { // } else { // } }
幾年前寫asp代碼的時候經(jīng)常用這樣的方法…
View變得簡單的,Controller復雜了。
太依賴說View,會存在一些問題。假若哪天客戶說按鈕上的文字改為“通過審核”,或者是做個多語言版的,那就麻煩了。
方法三:使用ActionSelector
關(guān)于ActionSelector的基本原理可以先看下這個POST使用ActionSelector控制Action的選擇。
使用此方法,我們可以將控制器寫成這樣:
[HttpPost] [MultiButton("action1")] public ActionResult Action1() { // return View(); } [HttpPost] [MultiButton("action2")] public ActionResult Action2() { // return View(); }
在 View中:
<input type="submit" value="審核通過" name="action1" /> <input type="submit" value="審核不通過" name="action2"/> <input type="submit" value="返回" name="action3"/>
此時,Controller已經(jīng)無須依賴于按鈕的Value值。
MultiButtonAttribute的定義如下:
public class MultiButtonAttribute : ActionNameSelectorAttribute { public string Name { get; set; } public MultiButtonAttribute(string name) { this.Name = name; } public override bool IsValidName(ControllerContext controllerContext, string actionName, System.Reflection.MethodInfo methodInfo) { if (string.IsNullOrEmpty(this.Name)) { return false; } return controllerContext.HttpContext.Request.Form.AllKeys.Contains(this.Name); } }
方法四:改進
Controller:
[HttpPost] [MultiButton(Name = "delete", Argument = "id")] public ActionResult Delete(string id) { var response = System.Web.HttpContext.Current.Response; response.Write("Delete action was invoked with " + id); return View(); }
View:
<input type="submit" value="not important" name="delete" /> <input type="submit" value="not important" name="delete:id" />
MultiButtonAttribute定義:
代碼
[AttributeUsage(AttributeTargets.Method, AllowMultiple = false, Inherited = true)] public class MultiButtonAttribute : ActionNameSelectorAttribute { public string Name { get; set; } public string Argument { get; set; } public override bool IsValidName(ControllerContext controllerContext, string actionName, MethodInfo methodInfo) { var key = ButtonKeyFrom(controllerContext); var keyIsValid = IsValid(key); if (keyIsValid) { UpdateValueProviderIn(controllerContext, ValueFrom(key)); } return keyIsValid; } private string ButtonKeyFrom(ControllerContext controllerContext) { var keys = controllerContext.HttpContext.Request.Params.AllKeys; return keys.FirstOrDefault(KeyStartsWithButtonName); } private static bool IsValid(string key) { return key != null; } private static string ValueFrom(string key) { var parts = key.Split(":".ToCharArray()); return parts.Length < 2 ? null : parts[1]; } private void UpdateValueProviderIn(ControllerContext controllerContext, string value) { if (string.IsNullOrEmpty(Argument)) return; controllerContext.Controller.ValueProvider[Argument] = new ValueProviderResult (value, value, null); } private bool KeyStartsWithButtonName(string key) { return key.StartsWith(Name, StringComparison.InvariantCultureIgnoreCase); } } //如果是在MVC 2.0中的話,將UpdateValueProviderIn方法改為: private void UpdateValueProviderIn(ControllerContext controllerContext, string value) { if (string.IsNullOrEmpty(Argument)) return; controllerContext.RouteData.Values[this.Argument] = value; }
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- ASP.NET MVC 微信JS-SDK認證
- asp.net如何進行mvc異步查詢
- Asp.net MVC中獲取控制器的名稱的方法
- ASP.NET MVC自定義錯誤頁面真的簡單嗎?
- ASP.NET MVC阿里大于短信接口開發(fā)短信群發(fā)能
- asp.net mvc4中bootstrap datetimepicker控件的使用
- Asp.NET MVC中使用SignalR實現(xiàn)推送功能
- ASP.NET Core MVC 配置全局路由前綴
- ASP.NET MVC5+EF6+EasyUI后臺管理系統(tǒng) 微信公眾平臺開發(fā)之資源環(huán)境準備
- ASP.NET MVC5+EF6+EasyUI后臺管理系統(tǒng) 微信公眾平臺開發(fā)之消息管理
- ASP.NET MVC中URL地址傳參的兩種寫法
- ASP.NET MVC5網(wǎng)站開發(fā)之登錄、驗證和注銷管理員篇1(六)
- 詳解ASP.NET MVC的篩選器
相關(guān)文章
Visual Studio 2017無法加載Visual Studio 2015創(chuàng)建的SharePoint解決方法
這篇文章主要為大家詳細介紹了Visual Studio 2017無法加載Visual Studio 2015創(chuàng)建的SharePoint的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-03-03Asp.Net?Core配置多環(huán)境log4net配置文件的全過程
在.NET世界中有非常多的日志框架,然而log4net是目前為止最流行的一款日志框架,下面這篇文章主要給大家介紹了關(guān)于Asp.Net?Core配置多環(huán)境log4net配置文件的相關(guān)資料,需要的朋友可以參考下2022-04-04詳解JQuery Ajax 在asp.net中使用總結(jié)
這篇文章主要介紹了詳解JQuery Ajax 在asp.net中使用總結(jié),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-01-01asp.net基于Web Service實現(xiàn)遠程上傳圖片的方法
這篇文章主要介紹了asp.net基于Web Service實現(xiàn)遠程上傳圖片的方法,涉及asp.net調(diào)用Web Service的文件流操作與文件傳輸實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-12-12FileUpload上傳圖片前實現(xiàn)圖片預覽功能(附演示動畫)
FileUpload控件上傳圖片前實現(xiàn)預覽,很多網(wǎng)友都希望實現(xiàn)這樣的功能,本人總結(jié)了一下,感興趣的朋友可以參考一下,希望對您有幫助2013-01-01