He estado escuchando mucho sobre MVVM para WPF.
¿Cuándo lo usamos?
¿Es un uso para todo o solo tiene usos específicos?
¿Vale la pena por cada proyecto?¿Cuándo usamos MVVM?
Respuesta
Puede ser útil en cualquier proyecto, pero me resulta especialmente útil en situaciones donde se requiere una separación clara entre lógica comercial, lógica de interacción e interfaz de usuario (aplicaciones grandes o aplicaciones que involucran múltiples desarrolladores/diseñadores).
Modelo = lógica de negocios
- Contiene el modelo de cualquier proceso de negocio/objeto que estoy trabajando con.
ViewModel = Interacción lógica
- todo el código que controla cómo se accede y se modifica el modelo (por ejemplo, editar/deshacer la funcionalidad, la carga diferida, etc.)
Ver = Interfaz de usuario
- La interfaz (definida en XAML) con la que el usuario interactúa. Intento minimizar el uso de código subyacente en esta capa, introduciéndolo en Propiedades adjuntas o en ViewModel.
Sin duda hay muchos otros usos para MVVM, pero este escenario particular es el que he encontrado que es el más útil en mi propia experiencia de desarrollo de WPF.
Lo he encontrado útil incluso en proyectos relativamente pequeños, si uso mucho el enlace de datos y un modelo/modelos de datos de objeto.
En términos de WPF y Silverlight?
En teoría para todo, cada proyecto no trivial (y posiblemente incluso entonces). Es parte de un proceso más amplio (crea separación de preocupaciones y permite pruebas y otras cosas agradables). Básicamente, si lo vas a hacer (y creo que probablemente quieras hacerlo, ciertamente tengo la intención de hacerlo con nuevos proyectos), entonces deberías hacerlo en general.
Si aún no lo has hecho, ve el video vinculado desde aquí: http://blog.lab49.com/archives/2650 - Me pareció muy útil para aclarar mis ideas.
Es mejor preguntar: cuando no debería lo usa? El ejemplo más obvio es cuando el enlace de datos no es apropiado y usted tiene que manipular elementos de la vista directamente en el código; si, por ejemplo, su aplicación necesita actualizar el estado visual de cientos o miles de elementos visuales en tiempo real, puede no poder pagar la sobrecarga de enlace de datos.
Actualmente estoy trabajando en un proyecto grande, donde implementamos mvvm, CAL (Guía de aplicaciones compuestas) en Silverlight. Por supuesto, el nivel de separación de preocupaciones es muy alto ... pero
1) el código se vuelve demasiado robusto.
2) MVVM se ve genial para proyectos pequeños (todas estas muestras de hello-world en Internet), pero reduce sus oportunidades: por ejemplo, los eventos enrutados (gran instrumento) siguen siendo EVENTOS, pero, como usted sabe, está estrictamente prohibido usarlos directamente, tan pronto como este código esté detrás) si quiere seguir mvvm.
3) Command Binding STILL no funciona correctamente en Silverlight (.net4.0, vs2010). Es una historia larga, solo tenga en cuenta esa sorpresa cuando su delegado CanExecute no se active al inicio de la aplicación.
Una buena respuesta a su pregunta es "MVVM es bueno para proyectos con lógica de IU simple".
Gracias, Ilya.
Cada vez que se inicia en un proyecto simple y pienso "esto es tan simple, MVVM sería una exageración", aproximadamente 8 horas más tarde llego a un punto en que me di cuenta que el uso de MVVM haría las cosas mucho más simple.
Así que yo diría que la mayoría de las veces el uso de MVVM en realidad simplificará su lógica de UI, incluso si inicialmente piensa que será excesivo. Los proyectos tienen la costumbre de volverse más complejos con el tiempo, y la separación de la lógica de negocios y la lógica de vista impuesta por MVVM permite que el proyecto crezca de una manera mucho más controlada que tener su lógica empresarial y de UI mezcladas todas juntas.
- 1. ¿Dónde/cuándo usamos JSON?
- 2. Cuándo usamos ANTLR
- 3. Cuándo usamos goto * expr; ¿Cª?
- 4. Calendario add() vs roll() ¿cuándo lo usamos?
- 5. ¿Cuándo usamos el servicio de Windows?
- 6. ¿Cuándo tiene sentido abandonar MVVM?
- 7. ¿Cuándo usamos el operador "|| =" en Rails? ¿Cuál es su significado?
- 8. ¿Cuándo NO se debe usar MVVM?
- 9. Cuándo desechar ViewModel en MVVM Light
- 10. Haskell, Ajustar: construcción sencilla snaplet. ¿Cuándo usamos snaplet y cuándo biblioteca?
- 11. MVVM Light Tipos de mensajes: ¿Cuándo usar cada tipo?
- 12. ¿Para qué usamos glyph?
- 13. ¿Por qué usamos web.xml?
- 14. ¿Por qué usamos Response.ClearHeaders()?
- 15. ¿Qué es InputStream y flujo de salida? ¿Por qué y cuándo los usamos?
- 16. ¿Cuál es el concepto de intención pendiente? ¿Por qué y cuándo usamos intención pendiente?
- 17. ¿Por qué usamos finalmente bloques?
- 18. Necesitamos mfence cuando usamos xchg
- 19. ¿Por qué usamos la serialización?
- 20. Por qué * debería * usamos EventHandler
- 21. ¿Por qué usamos "({})" en jQuery?
- 22. ¿Por qué exactamente usamos NoSQL?
- 23. @Generated Annotation, ¿cómo lo usamos?
- 24. MVVM Foundation vs MVVM Toolkit
- 25. MVVM para desarrollo web
- 26. MVVM enrutado y comando de relé
- 27. Qt moveToThread() vs llamada nueva cadena cuando usamos cada
- 28. ¿Por qué usamos Virtual y Override?
- 29. ¿Para qué usamos CURLOPT_WRITEFUNCTION en PHP cURL?
- 30. ¿Por qué usamos la anotación de hibernación?