成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

ASP.NET MVC使用Session會話保持表單狀態

瀏覽:211日期:2022-06-08 17:44:49

本篇實踐在ASP.NET MVC 4下使用Session來保持表單的狀態。

如上,輸入俱樂部名稱,點擊"添加球員",輸入球員名稱。我們希望,點擊"到別的地方轉轉"跳轉到另外一個視圖頁,當再次返回的時候能保持表單的狀態。

點擊"到別的地方轉轉"跳轉到另外一個視圖頁如下:

再次返回,表單的狀態被保持了:

點擊"提交"按鈕,顯示表單的內容:

關于球員,對應的Model為:

using System.ComponentModel.DataAnnotations;namespace MvcApplication1.Models{    public class Player    {public int Id { get; set; }[Required(ErrorMessage = "必填")][Display(Name = "球員名稱")]public string Name { get; set; }    }}

關于俱樂部,對應的Model為:

using System.Collections.Generic;using System.ComponentModel.DataAnnotations;namespace MvcApplication1.Models{    public class Club    {public Club(){    this.Players = new List<Player>();}public int Id { get; set; }[Required(ErrorMessage = "必填")][Display(Name = "俱樂部名稱")]public string Name { get; set; }public List<Player> Players { get; set; }    }}

在Home/Index.cshtml強類型視圖中,

@model MvcApplication1.Models.Club@{    ViewBag.Title = "Index";    Layout = "~/Views/Shared/_Layout.cshtml";}<h2>Index</h2>@using (Html.BeginForm("Index", "Home", FormMethod.Post, new {id = "myForm"})){    @Html.LabelFor(m => m.Name)    @Html.TextBoxFor(m => m.Name)    @Html.ValidationMessageFor(m => m.Name)    <br/><br/>        <ul id="players">@if (Model.Players != null){    foreach (var item in Model.Players)    {Html.RenderAction("NewPlayerRow", "Home", new { player = @item });    }    }    </ul>    <a id="addPlayer" href="javascript:void(0)" rel="external nofollow"  rel="external nofollow" >添加球員</a>        <br/><br/>        <div><a href="javascript:void(0)" rel="external nofollow"  rel="external nofollow"   id="gotoOther">到別的地方轉轉</a> &nbsp;<input type="submit" id="up" value="提交" />    </div>}@section scripts{    <script src="~/Scripts/dynamicvalidation.js"></script>    <script type="text/javascript">$(function () {    //添加關于Player的新行    $("#addPlayer").on("click", function() {createPlayerRow();    });    //到別的頁    $("#gotoOther").on("click", function() {if ($("#myForm").valid()) {    $.ajax({cache: false,url: "@Url.Action("BeforeGoToMustSave", "Home")",type: "POST",dataType: "json",data: $("#myForm").serialize(),success: function (data) {    if (data.msg) {window.location.href = "@Url.Action("RealGoTo", "Home")";    }},error: function (xhr, status) {    alert("添加失敗,狀態碼:" + status);}    });}    });});//添加品牌行function createPlayerRow() {    $.ajax({cache: false,url: "@Url.Action("NewPlayerRow", "Home")",type: "GET",data: {},success: function (data) {    $("#players").append(data);    $.validator.unobtrusive.parseDynamicContent("#players li:last", "#myForm");},error: function (xhr, status) {    alert("添加行失敗,狀態碼:" + status);}    });}    </script>}

以上,

  • 點擊"添加球員",向控制器發出異步請求,把部分視圖li動態加載到ul中
  • 點擊"到別的地方轉轉",向控制器發出異步請求,正是在這時候,在控制器的Action中,實施把表單的狀態保存到Session中
  • 點擊"提交"按鈕,把表單信息顯示出來

另外,當在頁面上點擊"添加球員",為了讓動態的部分視圖能被驗證,需要引入dynamicvalidation.js,調用其$.validator.unobtrusive.parseDynamicContent('#players li:last', "#myForm")方法,dynamicvalidation.js具體如下:

//對動態生成內容客戶端驗證(function ($) {    $.validator.unobtrusive.parseDynamicContent = function (selector, formSelector) {$.validator.unobtrusive.parse(selector);var form = $(formSelector);var unobtrusiveValidation = form.data("unobtrusiveValidation");var validator = form.validate();$.each(unobtrusiveValidation.options.rules, function (elname, elrules) {    if (validator.settings.rules[elname] == undefined) {var args = {};$.extend(args, elrules);args.messages = unobtrusiveValidation.options.messages[elname];//edit:use quoted strings for the name selector$("[name="" + elname + ""]").rules("add", args);    } else {$.each(elrules, function (rulename, data) {    if (validator.settings.rules[elname][rulename] == undefined) {var args = {};args[rulename] = data;args.messages = unobtrusiveValidation.options.messages[elname][rulename];//edit:use quoted strings for the name selector$("[name="" + elname + ""]").rules("add", args);    }});    }});    };})(jQuery);

在HomeController中,

   public class HomeController : Controller    {private const string sessionKey = "myFormKey";public ActionResult Index(){    Club club = null;    if (Session[sessionKey] != null)    {club = (Club) Session[sessionKey];    }    else    {club = new Club();    }    return View(club);}//提交表單[HttpPost]public ActionResult Index(Club club){    if (ModelState.IsValid)    {StringBuilder sb = new StringBuilder();sb.Append(club.Name);if (club.Players != null && club.Players.Count > 0){    foreach (var item in club.Players)    {sb.AppendFormat("--{0}", item.Name);    }}//刪除Session//Session.Abandon();//Session.Clear();Session.Remove(sessionKey);return Content(sb.ToString());    }    else    {return View(club);    }}//添加新行public ActionResult NewPlayerRow(Player player){    return PartialView("_NewPlayer", player ?? new Player());}//跳轉之前把表單保存到Session中[HttpPost]public ActionResult BeforeGoToMustSave(Club club){    Session[sessionKey] = club;    return Json(new { msg = true });}//保存完Club的Session后真正跳轉到的頁面public ActionResult RealGoTo(){    return View();}    }

以上,

  • 對于接收[HttpGet]請求的Index方法對應的視圖,Session存在就從Session中取出Club實例,否則就創建一個空的club實例
  • 對于接收[HttpPost]請求的Index方法對應的視圖,顯示表單內容之前把對應的Session刪除
  • 添加新行NewPlayerRow方法供顯示或添加用,當Player類型參數為null的時候,實際就是點擊"添加球員"顯示新行
  • BeforeGoToMustSave方法實際是為了在跳轉之前保存Session
  • RealGoTo是點擊"到別的地方轉轉"后真正跳轉的視圖頁

另外,所有視圖頁的公共頁Layout.cshtml,必須引用異步驗證的js。

<head>    <meta charset="utf-8" />    <meta name="viewport" content="width=device-width" />    <title>@ViewBag.Title</title>    @Styles.Render("~/Content/css")    @Scripts.Render("~/bundles/jquery")    @Scripts.Render("~/bundles/jqueryval")</head><body>    @RenderBody()        @RenderSection("scripts", required: false)</body>

Home/_NewPlayer.cshtml部分視圖,是在點擊"添加球員"之后動態加載的部分視圖。

@using MvcApplication1.Extension@model MvcApplication1.Models.Player<li >     @using (Html.BeginCollectionItem("Players"))      {@Html.HiddenFor(model => model.Id) <div>     @Html.LabelFor(m => m.Name)     @Html.TextBoxFor(m => m.Name)     @Html.ValidationMessageFor(m => m.Name) </div>       }</li>

其中,用到了擴展Extension文件夾下CollectionEditingHtmlExtensions類的擴展方法,如下:

using System;using System.Collections.Generic;using System.Web;using System.Web.Mvc;namespace MvcApplication1.Extension{    public static class CollectionEditingHtmlExtensions    {//目標生成如下格式//<input autocomplete="off" name="FavouriteMovies.Index" type="hidden" value="6d85a95b-1dee-4175-bfae-73fad6a3763b" />//<label>Title</label>//<input name="FavouriteMovies[6d85a95b-1dee-4175-bfae-73fad6a3763b].Title" type="text" value="Movie 1" />//<span></span>public static IDisposable BeginCollectionItem<TModel>(this HtmlHelper<TModel> html, string collectionName){    //構建name="FavouriteMovies.Index"    string collectionIndexFieldName = string.Format("{0}.Index", collectionName);    //構建Guid字符串    string itemIndex = GetCollectionItemIndex(collectionIndexFieldName);    //構建帶上集合屬性+Guid字符串的前綴    string collectionItemName = string.Format("{0}[{1}]", collectionName, itemIndex);    TagBuilder indexField = new TagBuilder("input");    indexField.MergeAttributes(new Dictionary<string, string>()    {{"name", string.Format("{0}.Index", collectionName)},{"value", itemIndex},{"type", "hidden"},{"autocomplete", "off"}    });    html.ViewContext.Writer.WriteLine(indexField.ToString(TagRenderMode.SelfClosing));    return new CollectionItemNamePrefixScope(html.ViewData.TemplateInfo, collectionItemName);}private class CollectionItemNamePrefixScope : IDisposable{    private readonly TemplateInfo _templateInfo;    private readonly string _previousPrfix;    //通過構造函數,先把TemplateInfo以及TemplateInfo.HtmlFieldPrefix賦值給私有字段變量,并把集合屬性名稱賦值給TemplateInfo.HtmlFieldPrefix    public CollectionItemNamePrefixScope(TemplateInfo templateInfo, string collectionItemName)    {this._templateInfo = templateInfo;this._previousPrfix = templateInfo.HtmlFieldPrefix;templateInfo.HtmlFieldPrefix = collectionItemName;    }    public void Dispose()    {_templateInfo.HtmlFieldPrefix = _previousPrfix;    }}/// <summary>/// /// </summary>/// <param name="collectionIndexFieldName">比如,FavouriteMovies.Index</param>/// <returns>Guid字符串</returns>private static string GetCollectionItemIndex(string collectionIndexFieldName){    Queue<string> previousIndices = (Queue<string>)HttpContext.Current.Items[collectionIndexFieldName];    if (previousIndices == null)    {HttpContext.Current.Items[collectionIndexFieldName] = previousIndices = new Queue<string>();string previousIndicesValues = HttpContext.Current.Request[collectionIndexFieldName];if (!string.IsNullOrWhiteSpace(previousIndicesValues)){    foreach (string index in previousIndicesValues.Split(","))    {previousIndices.Enqueue(index);    }}    }    return previousIndices.Count > 0 ? previousIndices.Dequeue() : Guid.NewGuid().ToString();}    }}

Home/RealGoTo.cshtml視圖,是點擊"到別的地方轉轉"后跳轉到的頁面,僅僅提供了一個跳轉到Home/Index視圖頁的鏈接。

@{    ViewBag.Title = "RealGoTo";    Layout = "~/Views/Shared/_Layout.cshtml";}<h2>RealGoTo</h2>@Html.ActionLink("回到表單頁","Index","Home")

本篇的源碼在這里: https://github.com/darrenji/KeepFormStateUsingSession

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對的支持。如果你想了解更多相關內容請查看下面相關鏈接

標簽: ASP.NET
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
日韩免费福利电影在线观看| 国精品**一区二区三区在线蜜桃| 国产制服丝袜一区| 欧美亚洲免费| 亚洲永久精品大片| 日韩亚洲国产欧美| 亚洲精品视频免费看| 在线看无码的免费网站| 国产精品麻豆网站| 国产精品激情电影| 国产精品久久免费看| 狠狠色噜噜狠狠色综合久| 国产精品毛片久久久久久| 午夜电影亚洲| 中文字幕乱码亚洲精品一区| 欧美日韩综合另类| 国产精品高清亚洲| 日韩一区二区久久| 亚洲成av人片一区二区梦乃 | 日韩一区二区电影网| 成人深夜视频在线观看| 欧美精品一区二区三区在线播放| 不卡视频一二三四| 国产欧美精品区一区二区三区| 欧美承认网站| 亚洲少妇最新在线视频| 国产欧美日韩在线播放| 亚洲免费在线看| 久久久久综合| 精品一区二区三区视频| 日韩欧美中文字幕一区| 波波电影院一区二区三区| 国产欧美综合在线| 中国成人亚色综合网站| 蜜臀91精品一区二区三区 | 94色蜜桃网一区二区三区| 久久精品亚洲精品国产欧美| 亚洲网站视频| 亚洲成av人片在线观看| 久久狠狠久久综合桃花| 麻豆精品一区二区综合av| 欧美军同video69gay| 秋霞午夜av一区二区三区| 欧美日本国产视频| 成人妖精视频yjsp地址| 国产精品免费看片| 国产亚洲毛片| 理论片日本一区| 精品88久久久久88久久久| 黄色成人精品网站| 香蕉加勒比综合久久| 51午夜精品国产| 色综合天天综合网天天看片| 一区二区三区在线免费视频| 国产精品日韩一区二区三区| 精品一区二区三区视频在线观看| 欧美精品一区男女天堂| 亚洲激情一区二区三区| 日韩成人一区二区三区在线观看| 欧美一二区视频| 在线不卡视频| 六月丁香婷婷色狠狠久久| 久久久久久久久岛国免费| 国产视频一区三区| 国模无码大尺度一区二区三区| 久久久电影一区二区三区| 亚洲一区二区伦理| 国产成人无遮挡在线视频| 中文字幕在线一区免费| 色呦呦一区二区三区| 亚洲国产精华液网站w| 国产美女娇喘av呻吟久久| 精品国产一区二区三区久久影院| 亚洲福利久久| 国产呦精品一区二区三区网站| 国产婷婷精品av在线| 亚洲欧美日本视频在线观看| 国产成人精品影视| 久久久777精品电影网影网| 国产精品久久亚洲7777| 国产aⅴ综合色| 亚洲最大成人网4388xx| 日韩一区二区三区免费看| 亚洲国产婷婷| 精东粉嫩av免费一区二区三区| 国产精品女人毛片| 欧美少妇性性性| 一区二区在线不卡| 国产精品77777竹菊影视小说| 一区二区三区中文字幕精品精品 | 国产精品国产成人国产三级| 欧美日韩www| 亚洲精品日韩久久| 国产福利精品一区| 一区二区三区四区蜜桃 | 久久精品道一区二区三区| 成人av在线播放网站| 亚洲国产成人av好男人在线观看| 日韩精品一区二区三区蜜臀 | 亚洲综合精品久久| 精品免费国产二区三区| 一本色道a无线码一区v| 午夜精品久久99蜜桃的功能介绍| 免费在线观看一区| 国产精品久久久久久亚洲伦| 欧美浪妇xxxx高跟鞋交| 99一区二区| a美女胸又www黄视频久久| 免费久久99精品国产| 亚洲日本在线a| 亚洲精品在线观看网站| 在线一区二区三区| 亚洲人人精品| 成人av片在线观看| 强制捆绑调教一区二区| 亚洲欧美区自拍先锋| 精品国产乱码久久久久久浪潮 | 久久人人超碰精品| 久久中文在线| 欧美日韩一区二区国产| 狠狠色丁香婷婷综合| 亚洲制服丝袜在线| 中文字幕高清不卡| 7777精品伊人久久久大香线蕉经典版下载| 国产精品免费在线| 欧美在线不卡| 粉嫩aⅴ一区二区三区四区 | 精品va天堂亚洲国产| 欧美精品久久天天躁| 在线免费高清一区二区三区| 亚洲三级在线播放| 欧美一区二区三区喷汁尤物| 久久综合图片| 雨宫琴音一区二区在线| 成人国产精品免费观看动漫| 久久99精品一区二区三区| 综合激情网...| 久久人人超碰精品| 欧美性猛片xxxx免费看久爱| 亚洲美女毛片| 午夜精品视频| 99精品在线免费| 国产一区视频导航| 日本aⅴ亚洲精品中文乱码| 亚洲欧洲一区二区在线播放| 欧美变态tickle挠乳网站| 欧美日免费三级在线| 久久三级福利| 性欧美精品高清| 最新成人av网站| 国产综合精品一区| 93久久精品日日躁夜夜躁欧美| 高清shemale亚洲人妖| 麻豆中文一区二区| 日韩在线a电影| 午夜成人在线视频| 亚洲线精品一区二区三区 | 久久亚洲欧美国产精品乐播 | 婷婷久久综合九色国产成人| 亚洲精品免费在线观看| 精品日韩一区二区| 日韩一级大片在线| 欧美男人的天堂一二区| 亚洲深夜福利| 伊人久久婷婷色综合98网| 国产精品v日韩精品v欧美精品网站 | 中文字幕一区视频| 中文字幕一区二区不卡| 中文字幕第一页久久| 国产精品亲子伦对白| 国产精品国产三级国产aⅴ原创 | 国产成人高清视频| 国产91精品免费| 国产成人精品免费视频网站| 国产一区二区三区av电影| 国产精品中文欧美| 粉嫩一区二区三区性色av| 99久久免费精品高清特色大片| 91片在线免费观看| 你懂的国产精品永久在线| 欧美日韩国产精品一区二区亚洲| 亚洲欧美影院| 国产精品国产亚洲精品看不卡15| 亚洲激情黄色| 香蕉久久夜色精品国产| 久久亚洲一区二区| 欧美嫩在线观看| 日韩欧美一级片| 精品国产欧美一区二区| 国产人久久人人人人爽| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 成人黄色综合网站| 99免费精品在线观看| 欧美国产91| 亚洲手机视频| 国产精品主播| 欧美色中文字幕| 日韩小视频在线观看专区| 欧美色成人综合| 日韩一区二区三区三四区视频在线观看|