zoukankan      html  css  js  c++  java
  • ASP.NET MVC controller 之间传JS值

    ASP.NET MVC controller 之间传JS值

    在ASP.NET MVC中有东西叫TempData,它的类型是TempDataDictionary,它与ViewData以及ViewBag的不同之处在于

    它的内部是使用session来保存信息的,可以理解为暂存的意思。虽然是通过session在保存信息,但它的生命周期是“一次网页的请求”。

    利用这一点,我们可以用它在做MVC 中action之间的传值。以下是我传值的一点经验,高手请忽略,呵呵。

    假如我们有一张学生管理的页面,其中有学生添加功能,以及学生展示列表。我们是通过一个Action来展示所有信息的,就像是web form一样

    那么在controller中会有这样一个action

    [HttpGet]
           public ActionResult Students()
           {
               ViewBag.title = "Add Student Page";
               ViewBag.jsMessage = TempData["jsMessage"] == null ? "" : TempData["jsMessage"].ToString();//判断并给ViewBag赋值
               return View(StudentsPage_Load());
           }

      要添加学生我们就必须有一个Add action如下:

    [HttpPost]
           public ActionResult Add(Students student)
           {
               if (ModelState.IsValid)
               {
                   StudentsBLL bll = new StudentsBLL();
                   bll.Add(student);
                   TempData["jsMessage"] = "alert('success');";//利用TempData暂存数据
               }
               return RedirectToAction("Students");
           }

      请注意上述代码中的注释部分,它是说添加成功之后,返回原有的页面。也就是说这个Add  action并没有对应的view。

         那么在添加学生成功之后要在原有的页面中用JS弹出一个添加成功的对话框。可以在Students的View中这样写

    <script type="text/javascript">
     @Html.Raw(@ViewBag.jsMessage)
    </script>

      其中@Html.Raw是表示不对输出进行转义。这里有个地方要注意。如果直接在cshtml文件中写

    TempData["jsMessage"]则会输出转义后的字符。但如果这样写的话:
    @Html.Raw(TempData["jsMessage"])
    页面的编译将会报错。所以必须在Students这个Action中加入
    ViewBag.jsMessage作为数据的承接。
     
     
    分类: ASP.NETC#
  • 相关阅读:
    Electron+Vue开发跨平台桌面应用
    html2canvas生成图片
    将某个DIV内容保存成图片,使用HTML2CANVAS截图方法(高清图并解决图片跨域问题)
    css3实现动画效果完整代码demo
    Vue + element从零打造一个H5页面可视化编辑器——pl-drag-template
    Vue.Draggable学习总结
    3d学习网
    vue router 报错: Uncaught (in promise) NavigationDuplicated {_name:""NavigationDuplicated"... 的解决方法
    网页适配 iPhoneX,就是这么简单
    关于for循环
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/3267273.html
Copyright © 2011-2022 走看看