ASP.NET MVC TempData同ASP.NET MVC ViewData一样,是在Controllers中声明的变量以便在Views中进行调用,示例代码如下所示。
[HandleError]
public class BetaController : Controller
{
public ActionResult Index()
{
TempData["beta"] = "TempData字符串";
return View();
}
}
上述代码在Controllers中声明了TempData,在Views中的相应页面可以使用此TempData进行变量的输出,示例代码如下所示。
<%@ Page
Language="C#"
AutoEventWireup="true" CodeBehind="Beta.aspx.cs" Inherits="_17_1.Views.Beta.Index" %>
<h2>About Us</h2>
<p>
<%=TempData["beta"] %>
</p>
上述代码呈现了TempData变量的值,运行后如图17-21所示。
在数据呈现上,TempData变量同ASP.NET MVC ViewData基本相同,但是TempData能够在跳转中保存值。当用户访问一个页面时,该页面的Controllers中包含TempData变量。当这个页面通过Redirect跳转到另一个页面时,另一个页面能够使用跳转页面的TempData变量。在跳转页面中,在跳转前可以编写TempData变量保存相应的值,示例代码如下所示。
[HandleError]
public class BetaController : Controller
{
public ActionResult Index()
{
TempData["Index"] = "这是跳转页面的字符串哦.."; //编写TempData
Response.Redirect("/Beta/Get"); //页面跳转
return View(); //返回视图
}
}
上述忽代码编写了一个TempData变量并将页面跳转到Get.aspx,这里在Beta文件夹下创建一个Get.aspx页面读取相应的TempData变量的值。创建完成后,编写HTML代码如下所示。
<%@ Page
Language="C#"
AutoEventWireup="true" CodeBehind="Get.aspx.cs" Inherits="_17_1.Views.Beta.Get" %>
<h2>接受传递的参数</h2>
<p>
<%=TempData["Index"] %>
</p>
编写了页面代码后还不能对页面进行访问,由于MVC编程模型中路径是访问的Controller中的方法,所以还需要在Controller中实现Get页面的方法,示例代码如下所示。
public ActionResult Get()
{
return View(); //返回默认视图
}
上述代码返回默认视图,当不给View方法进行参数传递,将会返回与方法同名的.aspx页面文件。这里没有对View方法传递参数,则返回的是Get.aspx页面视图,当用户访问/Beta/路径时,代码会创建一个TempData变量并跳转到/Beta/Get路径,在/Beta/Get路径相应的文件中可以获取跳转前的TempData变量的值,运行后如图17-22所示。
在Get.aspx页面相应的实现代码中并没有声明任何的TempData变量,而是在跳转前的页面中声明的TempData变量,与ViewData相比跳转后的页面能够获取TempData变量的值而不能获取ViewData的值,这在某些应用场合如抛出异常等情况下非常适用。
注意:TempData变量在跳转中能够跨页面进行数据读取,但是跨页面跳转后TempData变量只能呈现一次。简单的说就是跳转的第一次能过获取跳转前页面的TempData变量的值,而再次操作时就无法使用跳转前页面的TempData变量值。