自我總結和學習表單提交的幾種方式 (一)

来源:http://www.cnblogs.com/CKExp/archive/2017/11/25/7895353.html
-Advertisement-
Play Games

最近總是記不住表單提交的幾種方式,並且各種方式的適應場景也不知道,乾脆來總結一次,當再學習過程。 首先從最簡單的開始練手: 【1】、純form表單形式,無js和ajax ,提交路徑有action決定,方式由method決定,如果需要傳輸文件加上enctype 我的表單內容:兩個下拉選擇、一個文件選擇 ...


最近總是記不住表單提交的幾種方式,並且各種方式的適應場景也不知道,乾脆來總結一次,當再學習過程。

首先從最簡單的開始練手:

【1】、純form表單形式,無js和ajax ,提交路徑有action決定,方式由method決定,如果需要傳輸文件加上enctype

我的表單內容:兩個下拉選擇、一個文件選擇和一個輸入框

        <form action="@Url.Action("AddFile", "Assistant")" id="form" method="post" class="form-horizontal" enctype="multipart/form-data" >
            <div class="form-group">
                @Html.LabelFor(m => m.FileDescription, new { @class = "col-md-2 control-label" })
                @Html.TextAreaFor(m => m.FileDescription, new { @class = "form-control col-md-10", rows = 5 })
            </div>
            <div class="form-group">
                @Html.LabelFor(m => m.FileType, new { @class = "col-md-2 control-label" })
                @Html.DropDownListFor(m => m.FileType, (IEnumerable<SelectListItem>)ViewBag.FileType, new { @class = "form-control col-md-10" })
            </div>
            <div class="form-group">
                @Html.LabelFor(m => m.File, new { @class = "col-md-2 control-label" })
                @Html.TextBoxFor(m => m.File, new { type = "file", id = "file", @class = "form-control col-md-10" })
            </div>
            <div class="form-group">
                @Html.LabelFor(m => m.IsPublic, new { @class = "col-md-2 control-label" })
                @Html.DropDownListFor(m => m.IsPublic, (IEnumerable<SelectListItem>)ViewBag.IsPublic, new { @class = "form-control col-md-10" })
            </div>
            <div class="form-group">
                <input type="submit" id="AddFile" class="btn col-md-offset-2" value="添加" />
                <button type="button" class="btn btn-default" data-dismiss="modal">關閉</button>
            </div>
        </form>

後臺成功接收到了需要的信息

這種方式最為簡便但是用處卻是不大,當我後臺需要返回信息時,前臺的回掉函數都沒有,就連是否提交成功都不知道。有朋友說可以有回掉函數,但註意這種使用的場景是無JS代碼無ajax。

 

【2】、基於【1】的擴展,利用Html輔助方法實現

        @using (Html.BeginForm("AddFile", "Assistant", FormMethod.Post, new { @class = "form-horizontal", enctype = "multipart/form-data",id="form" }))
        {
            <div class="form-group">
                @Html.LabelFor(m => m.FileDescription, new { @class = "col-md-2 control-label" })
                @Html.TextAreaFor(m => m.FileDescription, new { @class = "form-control col-md-10", rows = 5 })
            </div>
            <div class="form-group">
                @Html.LabelFor(m => m.FileType, new { @class = "col-md-2 control-label" })
                @Html.DropDownListFor(m => m.FileType, (IEnumerable<SelectListItem>)ViewBag.FileType, new { @class = "form-control col-md-10" })
            </div>
            <div class="form-group">
                @Html.LabelFor(m => m.File, new { @class = "col-md-2 control-label" })
                @Html.TextBoxFor(m => m.File, new { type = "file",id="file", @class = "form-control col-md-10" })
            </div>
            <div class="form-group">
                @Html.LabelFor(m => m.IsPublic, new { @class = "col-md-2 control-label" })
                @Html.DropDownListFor(m => m.IsPublic, (IEnumerable<SelectListItem>)ViewBag.IsPublic, new { @class = "form-control col-md-10" })
            </div>
            <div class="form-group">
                <input type="submit" id="AddFile" class="btn col-md-offset-2" value="添加" />
                <button type="button" class="btn btn-default" data-dismiss="modal">關閉</button>
            </div>
        }

實現效果和【1】是一樣的,只是這樣寫起來會感覺方便些

 

【3】Ajax.BeginForm方式,利用Ajax的輔助方法

這種集合了ajax和表單提交的非同步方式,

需要註意的是這種方式需要改變點東西,首先得增加一個js包,這個包如果框架沒有預設帶上可以從nuget中下載一個。

<script src="/Scripts/jquery.unobtrusive-ajax.min.js" type="text/javascript"></script>

還需要再配置中開啟允許

雖然這兩步驟已經由框架自動設置好了,但還是得知道下。

開始實踐:

@using (Ajax.BeginForm("AddFile", "Assistant", new AjaxOptions {HttpMethod = "Post",OnSuccess= "success"}, new { @class = "form-horizontal", enctype = "multipart/form-data", id = "form" }))
        {
            <div class="form-group">
                @Html.LabelFor(m => m.FileDescription, new { @class = "col-md-2 control-label" })
                @Html.TextAreaFor(m => m.FileDescription, new { @class = "form-control col-md-10", rows = 5 })
            </div>
            <div class="form-group">
                @Html.LabelFor(m => m.FileType, new { @class = "col-md-2 control-label" })
                @Html.DropDownListFor(m => m.FileType, (IEnumerable<SelectListItem>)ViewBag.FileType, new { @class = "form-control col-md-10" })
            </div>
            <div class="form-group">
                @Html.LabelFor(m => m.File, new { @class = "col-md-2 control-label" })
                @Html.TextBoxFor(m => m.File, new { type = "file", id = "file", @class = "form-control col-md-10" })
            </div>
            <div class="form-group">
                @Html.LabelFor(m => m.IsPublic, new { @class = "col-md-2 control-label" })
                @Html.DropDownListFor(m => m.IsPublic, (IEnumerable<SelectListItem>)ViewBag.IsPublic, new { @class = "form-control col-md-10" })
            </div>
            <div class="form-group">
                <input type="submit" id="AddFile" class="btn col-md-offset-2" value="添加" />
                <button type="button" class="btn btn-default" data-dismiss="modal">關閉</button>
            </div>
        }

首先看看Ajax.BeginForm的幾種重載實現

public static MvcForm BeginForm(this AjaxHelper ajaxHelper, string actionName, string controllerName, AjaxOptions ajaxOptions);
public static MvcForm BeginForm(this AjaxHelper ajaxHelper, string actionName, string controllerName, RouteValueDictionary routeValues, AjaxOptions ajaxOptions, IDictionary<string, object> htmlAttributes);    
public static MvcForm BeginForm(this AjaxHelper ajaxHelper, string actionName, string controllerName, RouteValueDictionary routeValues, AjaxOptions ajaxOptions);    
public static MvcForm BeginForm(this AjaxHelper ajaxHelper, string actionName, string controllerName, object routeValues, AjaxOptions ajaxOptions);
public static MvcForm BeginForm(this AjaxHelper ajaxHelper, string actionName, RouteValueDictionary routeValues, AjaxOptions ajaxOptions, IDictionary<string, object> htmlAttributes);
public static MvcForm BeginForm(this AjaxHelper ajaxHelper, string actionName, string controllerName, object routeValues, AjaxOptions ajaxOptions, object htmlAttributes);
public static MvcForm BeginForm(this AjaxHelper ajaxHelper, string actionName, object routeValues, AjaxOptions ajaxOptions, object htmlAttributes);
public static MvcForm BeginForm(this AjaxHelper ajaxHelper, string actionName, object routeValues, AjaxOptions ajaxOptions);
public static MvcForm BeginForm(this AjaxHelper ajaxHelper, string actionName, RouteValueDictionary routeValues, AjaxOptions ajaxOptions);
public static MvcForm BeginForm(this AjaxHelper ajaxHelper, string actionName, AjaxOptions ajaxOptions);
public static MvcForm BeginForm(this AjaxHelper ajaxHelper, AjaxOptions ajaxOptions);

都是很常見的參數,其中有一個AjaxOptions值得我們去看一番

 

果然是不錯啊  在這裡結合js代碼使用,定義幾個函數,實現需要的不同的回掉的功能。

 

實驗下,同樣起了效果,和【1】的效果是一樣的。併在此基礎上得到了回掉功能,此處需要說明下,回掉函數如果需要參數,預設參數是這樣的。

可參考jquery.unobtrusive-ajax.js 源碼

OnBegin – xhr
OnComplete – xhr, status
OnSuccess – data, status, xhr
OnFailure – xhr, status, error

也就是說我在js代碼中如果要用到返回的信息,可以在指定的參數中取到

在js中接收函數寫明參數信息

function success(data,status,xhr,此處還可自己擴展需要的參數信息){

  ......

}

html中如果需要增加額外參數可以這麼寫

  Onsuccess="success(data,status,xhr,此處還可自己擴展需要的參數信息)"

 

實踐中,我的回掉函數得到了信息

function success(data, status, xhr){
        if (data.result) {
            layer.alert("添加成功!");
            $("#myModal").modal("hide");//隱藏彈框
        }
    }

效果展示

 

此處說明下,當我沒有加上這個包時,ajax輔助方法可以將文件提交到後臺並正常接收,但是一旦加上這個包,後臺便接收不到文件了,需要引起註意。

<script src="/Scripts/jquery.unobtrusive-ajax.min.js" type="text/javascript"></script>

 劃重點:ajax輔助方法表單提交時如果不需要提交文件且需要回掉函數,那麼這種方式很不錯,但是如果需要提交文件,那麼受到上面那個包的影響,文件將不能提交成功,如有知道解決方案的,可以告知我,我也想學習學習。

 

今天只嘗試了三種方式,還剩下幾種其它形式的利用js提交(包括ajax提交)、form插件提交的幾種方式還沒來的及介紹。需要去買菜啦,哈哈。下一期再寫一篇。希望博友們推薦更多form表單提交的方式,感謝。

 

2017-11-25,望技術有成後能回來看見自己的腳步。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 第一章 HTTP 1.1 HTTP協議的概念 HTTP協議,全稱HyperText Transfer Protocol,中文名為超文本傳輸協議,是互聯網上常用的通信協議之一,它有很多的應用。但是流行的就是用於Web瀏覽器和Web伺服器之間的通信,即WWW應用或稱為Web應用。WWW全稱World W ...
  • 隱式轉換[自動類型轉換]: 兩種類型要相容,原類型值域要小於目標類型值域,可以簡單的理解為由小轉大。 1 public class Test 2 { 3 private void Start() 4 { 5 int a = 10; 6 float b = a;//int 類型隱式轉換為 float ...
  • 一個已經寫好的項目中有多個WebService,由於之前沒有記錄請求信息的,有時候需要查錯等需要找到當次的請求信息,所以需要加入記錄請求信息的功能。 首先想到的是在每一個帶有WebMethod特性的方法里調用記錄請求信息的方法,這樣可以記錄信息,但是太多帶WebMethod特性的方法了,於是想在全局 ...
  • 最近在搞jenkins pipeline的部署工作,而在對.net core進行部署時不希望安裝dotnet sdk,為了移植性更好,打算直接使用aspnetcore的docker鏡像,通過docker去run它,而在這個時間出現了一個問題 docker run aspnetcore:2.0之後如果 ...
  • 構造方法:用於實例化對象。 一般情況下,類或者結構體中都會存在一個預設的無參構造方法。如果我們在類中手動書寫了有參的構造方法,那麼這個無參構造方法就會被覆蓋掉;但是結構體中卻不會被覆蓋,即使我們在結構體中書寫了有參構造方法,無參構造方法依然可以使用。 【在使用單例模式時,我們可以書寫 private ...
  • 作者:地溝油 進入首頁 前言: 由於系統顏色太單調,所以決定啟用DevExpress換膚功能,讓界面更美觀! 作者的DevExpress已更換到17.2.3了,不過要是不想升級的話,也可以繼續沿用舊版的DevExpress喲,因為舊的和新的區別不大喲! 1.首先我們進入Program,在Main() ...
  • 前言 混跡.Net圈子已經好幾年了, 從最初出來使用的SqlHelper 到 微軟的企業庫, 再到 EF, 再到第三方ORM框架, 經歷了一個不可描述的過程, SqlHelper和企業庫就不多說了. EF很強大, 但是.....(此處省去一萬字), 尋尋覓覓最後發現了幾個國內的ORM, 都使用過,  ...
  • 1、面向介面: 通過介面約束對象的一些方法和屬性,屬於面向對象中的一部分。 更好的方式是「面向抽象」:先定義介面約束,再定義抽象類,在抽象類中實現公共方法,在進行具體實現。 總結:統一行為 2、面向對象: 通過封裝、繼承、多態更加有效的組織程式。 總結:提高復用 3、面向方面: 把業務的主邏輯和次邏 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...