07 August 2017

ViewBag vs TempData vs Session




ViewData



  1. ViewData is a dictionary object that is derived from ViewDataDictionary class.

    1. public ViewDataDictionary ViewData { get; set; }



  2. ViewData is a property of ControllerBase class.

  3. ViewData is used to pass data from controller to corresponding view.

  4. It’s life lies only during the current request.

  5. If redirection occurs then it’s value becomes null.

  6. It’s required typecasting for getting data and check for null values to avoid error.


ViewBag



  1. ViewBag is a dynamic property that takes advantage of the new dynamic features in C# 4.0.

  2. Basically it is a wrapper around the ViewData and also used to pass data from controller to corresponding view.

    1. public Object ViewBag { get; }



  3. ViewBag is a property of ControllerBase class.

  4. It’s life also lies only during the current request.

  5. If redirection occurs then it’s value becomes null.

  6. It doesn’t required typecasting for getting data.



TempData



  1. TempData is a dictionary object that is derived from TempDataDictionary class and stored in short lives session.

    1. public TempDataDictionary TempData { get; set; }



  2. TempData is a property of ControllerBase class.

  3. TempData is used to pass data from current request to subsequent request (means redirecting from one page to another).

  4. It’s life is very short and lies only till the target view is fully loaded.

  5. It’s required typecasting for getting data and check for null values to avoid error.

  6. It is used to store only one time messages like error messages, validation messages. To persist data with TempData refer this article: Persisting Data with TempData


Session



  1. In ASP.NET MVC, Session is a property of Controller class whose type is HttpSessionStateBase.

    1. public HttpSessionStateBase Session { get; }



  2. Session is also used to pass data within the ASP.NET MVC application and Unlike TempData, it persists for its expiration time (by default session expiration time is 20 minutes but it can be increased).

  3. Session is valid for all requests, not for a single redirect.

  4. It’s also required typecasting for getting data and check for null values to avoid error.