👽
3ntr0 Apuntes
  • 📚Principios SOLID y Clean Code
    • 💲Deuda Técnica
    • 📌Mejorar Nombres
      • 📄Nombre según Tipo
      • 🚗Nombre Clases
      • ⚙️Nombres Funciones
    • ☑️Mejorar Funciones
    • ➿Principio DRY
    • 🧼Clean Code en Clases (POO)
      • 📘 Principio de Responsabilidad Única (SRP)
    • 🤮🇸 🇹 🇺 🇵 🇮 🇩 - Code Smells
      • 🚫Singleton
      • 🙏Tight Coupling
      • 🥸U P I D
      • 🚩Más Code Smells
  • 💕Angular
    • 🏍️Standalone
    • 🆚ngClass vs [class.clase]
    • 🩻Directivas
    • 🚩ElementRef
    • 🎀Decoradores
      • @HostListener
    • 🔄OnChanges
    • 🧪Testing - Jasmine y Karma
      • 🚀Módulo 1: Introducción a las pruebas unitarias
      • 🧫Módulo 2: Introducción a Jasmine
      • ⚒️Módulo 3: Introducción a Karma
      • 🔬Módulo 4: Pruebas unitarias en Angular
        • Código comentado Paso a Paso
      • 🕵️‍♂️Módulo 5: Técnicas avanzadas en Jasmine
      • 📚Módulo 6: Técnicas avanzadas en Karma
  • 🖼️HTML y CSS
    • 🖌️Custom Properties
    • Trucos
    • Brakepoints
  • 🧋Javascript
    • 🛠️Funciones
    • 📦Arrays
      • Every y Some
      • Map
      • Reduce
    • 😎Hoisting
    • 🪚Desestructuración
    • 🛻Programación Asincrona
      • 📞Callbacks
      • 🌟Promises
      • 🆚Promise.all Y Promise.any
      • 🚀Async/Await
    • Respuestas HTTP
    • 🧐Dudas Básicas
      • NodeList
      • 🧐Contextos de .this
      • 💭Parametro Rest
      • 🗨️arguments
      • 🙀JavaScript no tiene clases
      • 🆚Null vs Undefined
      • 🔎Operador in
      • 🟨Operador Spread
      • ❓Encadenamiento Opcional
      • 🔲Notación de Corchetes
      • ⛓️Coalescencia Nula (??)
      • 🆚Shallow Copy vs Deep Copy
      • 🆚.json VS JSON.parse
      • ⚙️Fetch wrapper
      • Sets
      • Maps
  • 📒Terminología
    • 💎Esenciales
    • Web
    • Javascript
  • 🌐GIT
    • Source Tree
  • 🧬React
    • 🫂Babel
  • 🔧 Fundamentos de C#
    • 🎛️General
      • 🧐Diferencia Equals y ==
      • 🧐Diferencia entre typeof y .GetType()
      • 📐Convenciones de Nomenclatura
    • 💠Summary
    • 📇.resx
    • 📄Strings
      • ⛓️Comparación de cadenas
    • 🧲Regex
    • 📦POO
      • 🚙Clases
        • ✏️Clase String
        • 📥Métodos de Acceso
        • ⚗️Métodos de Extensión
    • 🖇️Pattern Matching
    • 🚩Excepciones
    • Programación Asíncrona
    • 🔎LINQ
      • 🅿️PLINQ
  • 🌐 Desarrollo Web con ASP.NET
    • 🧬Modelos
      • 🗒️Data Annotations
        • 📑Lista
        • 🧪Atributos
          • 🛠️Atributos Personalizados
          • 🧰AttributeUsage
          • 📥Acceso a los atributos
        • 📚Documentación
    • 👷Servicios
      • ⭐Servicios Singleton
    • ⏳Sesiones
      • 🧭Temp Data
    • DbContext
      • 🔄Eager Loading
    • 🥽Manejo de Datos
      • 🗃️Archivos
        • 📤Subida de Archivos
        • ✏️Leer y Escribir
        • 🕓Manejo de Archivos Temporales
        • 🛡️Validación de Archivos en ASP.NET Core
      • Colecciones
        • 🪜Pila (Stack)
        • 🏇Cola (Queue)
      • 🩻Manejo de XMLs
        • 📂XmlDocument
          • 🎯XPath
        • 🧿XmlReader
    • ❤️Tips y Utilities
      • 🟰StringComparison
    • 🧰Debug Tools
      • 🧭Stopwatch
  • 🚀Razor
    • 🧱Configuración de Proyecto
    • 📃Pages
      • 🔸Método OnGet
      • 🔸Carpeta Models
      • 🔸Partial Pages
    • 🎨Layouts
      • Aplicar CSS A UNA PAGE
    • 🚴‍♂️Routing
    • 🏢_ViewImports
    • ✒️Sintaxis Razor
      • 😀Introducción
      • 📔Expresiones Implícitas
      • 📕Expresiones Explícitas
      • ✍️Renderizar Texto
      • 🧑‍🔬Class Page Model
      • 🔖Tag Helpers
        • 🔹asp-page
        • 🔹asp-append-version
        • 🔹asp-for
        • 🔹asp-items
        • 🔹asp-action y asp-controller
  • 🔮LUA
    • 🎯Fundamentos
    • ⌨️Entrada por Consola
    • 🔗Estructuras de Control
    • ⚒️Funciones
    • 📦Tablas
    • 📚Funciones y Librerías Estándar
    • 🦖POO
Con tecnología de GitBook
En esta página
  • Uso Básico de TempData
  • Mostrando Mensajes de Error con TempData
  • Persistiendo Datos en TempData
  • Consejos y Mejores Prácticas
  1. 🌐 Desarrollo Web con ASP.NET
  2. Sesiones

Temp Data

TempData es un diccionario de almacenamiento temporal que se utiliza para pasar datos entre acciones en ASP.NET Core. Lo que hace especial a TempData es que los datos que almacenas en él están disponibles para la siguiente solicitud y se eliminan automáticamente después de eso. Es perfecto para mensajes de error, confirmación, o cualquier otro tipo de datos que solo necesites de manera temporal entre dos solicitudes.

Uso Básico de TempData

Para almacenar un valor en TempData, simplemente asigna un valor a una clave, similar a cómo lo harías con un diccionario:

TempData["Mensaje"] = "Este es un mensaje temporal.";

Para leer y mostrar este mensaje en una vista o en otra acción, accedes a él usando la misma clave:

var mensaje = TempData["Mensaje"] as string;

Recuerda que una vez que accedes a los datos en TempData, se marcan para eliminación al final de la solicitud.

Mostrando Mensajes de Error con TempData

Imagina que quieres mostrar un mensaje de error después de que un usuario intente subir un archivo inválido:

  1. En tu acción POST, al detectar un error:

TempData["ErrorMensaje"] = "Formato de archivo no válido.";
return RedirectToAction("TuAccion");
  1. En la acción a la que rediriges o en la vista correspondiente:

@if(TempData["ErrorMensaje"] != null)
{
    <script>
        alert('@TempData["ErrorMensaje"]');
    </script>
}

Persistiendo Datos en TempData

Si necesitas que los datos en TempData sobrevivan a más de una redirección, puedes usar TempData.Keep():

var mensaje = TempData["Mensaje"] as string;
TempData.Keep("Mensaje"); // Esto asegura que "Mensaje" esté disponible para una solicitud más.

Consejos y Mejores Prácticas

  • Usa TempData con moderación, principalmente para transferencias de datos de corta duración entre solicitudes, como mensajes flash.

  • Para datos que necesiten persistir más allá de una solicitud, considera usar otras técnicas como ViewData, ViewBag, o pasar modelos a las vistas.

  • Siempre verifica si TempData contiene la clave que buscas antes de intentar acceder a ella para evitar errores.

AnteriorSesionesSiguienteDbContext

Última actualización hace 1 año

⏳
🧭