Digamos que estoy escribiendo una aplicación web de blog usando el patrón MVC. El diseño típico de la página principal de la aplicación de blog es: algún tipo de índice de publicación en la parte principal, y aparte hay algunas partes adicionales, como la línea de tiempo, el panel de navegación de etiquetas, el panel de suscripción, etc. Esos controles también aparecen en un solo vista de publicación, y puede aparecer en otras vistas que tengo.
Mi pregunta es: ¿cómo debo manejar esos paneles a un lado en mis vistas y controladores? Veo tres enfoques aquí:
Cree una clase de modelo de vista grande que contenga toda la información requerida para representar las vistas (ya sea índice o publicación única). Ese caso podría hacer que estos paneles a un lado sean vistas parciales, y llamarlos desde la vista que se representa pasando parte de ese gran modelo de vista. El inconveniente es que tendré el código que llena el modelo de vista distribuido entre varios métodos de controlador, lo que significa que el código está duplicado. Lo cual es bastante malo.
Cree otra capa de representación de vista. Digamos, la capa superior de renderizado recibe partes ya representadas de html, o funciones que cuando se llama generan un html. La capa debajo de esta "capa de combinación de parciales" daría solo vistas parciales para cada panel que desee, incluyendo contenido principal. El inconveniente aquí: uso de memoria. La mayoría de los marcos modernos procesan htmls directamente en la secuencia de salida, pero en este enfoque las vistas parciales se procesarían primero en objetos de cadena, lo que lleva a una sobrecarga de memoria.
- Use algo como "RenderAction" de asp.net mvc, que llama a un método de controlador desde una vista. Creo que esta es la peor solución de 3 dado, porque deja caer un enfoque MVC.
La pregunta no está vinculada a ningún marco específico, quiero entender la forma general de hacer cosas así.
ACTUALIZAR
Después de una respuesta dada, descubrí que la publicación no está clara. Así que una actualización razonable aquí:
Bajo el término viewmodel , entiendo un objeto que contiene todos los datos necesarios para representar una vista en particular.
Los tres enfoques implican la construcción de vistas parciales con su propio modelo de vista. Por ejemplo (usando la sintaxis de C #):
class SinglePostViewModel {
string Text {get;set;}
string Title {get;set;}
string Slug {get;set;}
DateTime PublishedDate {get;set;}
...
}
class TagNavigationPanelViewModel {
string TagText {get;set;}
int PostsCount {get;set;}
}
class CalendarNavigationPanelViewModel {
DateTime YearAndMonth {get;set;}
int PostsCount {get;set;}
}
Mi pregunta es: cómo combinar bien esas vistas parciales.