Fork me on GitHub
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#
posted on 2013-08-19 10:14  HackerVirus  阅读(514)  评论(0编辑  收藏  举报