Versões comparadas

Chave

  • Esta linha foi adicionada.
  • Esta linha foi removida.
  • A formatação mudou.
Painel
titleIntrodução

O padrão MVVM ajuda a separar claramente a lógica de negócios negócio e apresentação de um aplicativo de sua interface de usuário (UI). Manter uma separação clara entre a lógica do aplicativo e a interface do usuário UI ajuda a resolver vários problemas de desenvolvimento e facilita o teste, a manutenção e a evolução de um aplicativo. Ele Ela também pode melhorar significativamente as oportunidades de reutilização de código e permite que desenvolvedores e designers de interface do usuário UI colaborem mais facilmente ao desenvolver suas respectivas partes de um aplicativo.

Além de entender as responsabilidades de cada componente, também é importante entender como eles interagem. Em um alto nível, a view “conhece” o view model e o view model “conhece” o model View conhece o ViewModel e o ViewModel conhece o Model, mas o model Model não conhece o view model ViewModel e o view model ViewModel não conhece a view View. Portanto, o view model ViewModel isola a view View do model Model e permite que o model Model evolua independentemente da view View.

Saiba mais

Painel
titleView

A view View é responsável por definir a estrutura, layout e aparência do que o usuário vê na tela. Idealmente, cada view View é definida em XAML, com um code-behind limitado que não contém a lógica de negócio. No entanto, em alguns casos, o code-behind pode conter lógica de interface do usuário que implementa um comportamento visual difícil de expressar em XAML, como animações.

Dica
titleDica
:
Dica

Evite habilitar e desabilitar elementos de interface no code-behind.

Painel
titleView Model

O view model ViewModel implementa propriedades e comandos aos quais a view View pode vincular dados e notifica a view -la de quaisquer alterações de estado por meio de eventos de notificação de alteração. As propriedades e comandos que o view model ViewModel fornece definem a funcionalidade a ser oferecida pela interface do usuário, mas a view View determina como essa funcionalidade deve ser exibida.

Embora seja possível expor a implementação real da interface ICommand do view model no ViewModel (por exemplo, Command<T> ou RelayCommand), é recomendável expor seus comandos publicamente como ICommand. Dessa forma, se for necessário alterar a implementação posteriormente, ela poderá ser facilmente trocada.

Dica
titleDicas
:
Dica
  • Mantenha a interface de usuário responsiva com operações assíncronas.
  • Centralize conversões de dados em uma camada de conversão.
  • Para coleções utilize ObservableCollection<T>.
Painel
titleModel

As classes model de modelo são classes não visuais que encapsulam os dados do aplicativo. Portanto, o model Model pode ser pensado como uma a representação do modelo de domínio do aplicativo, que geralmente inclui um modelo de dados junto juntamente com a lógica de negócio e validação. Exemplos de objetos de modelo incluem : objetos de transferência de dados (DTOs) , objetos CLR antigos simples e Plain Old CLR Objects (POCOs) e objetos de entidade e proxy gerados.
As classes de modelo são normalmente usadas em conjunto com serviços ou repositórios que encapsulam o acesso a dados e o armazenamento em cache.

Painel
titleImportante
Aviso

Os aplicativos devem ser arquitetados para o uso correto da propriedade do evento PropertyChanged, atendendo aos seguintes requisitos:

  • Sempre disparar um evento PropertyChanged para quaisquer propriedades calculadas cujos valores sejam usados ​​por outras propriedades no model Model ou view model ViewModel.
  • Sempre disparar um evento PropertyChanged no final do método que faz uma alteração de propriedade, ou quando se sabe que o objeto está em um estado seguro. Gerar o evento interrompe a operação invocando os manipuladores do evento de forma síncrona. Se isso acontecer no meio de uma operação, poderá expor o objeto a funções de retorno de chamada quando estiver em um estado não seguro e parcialmente atualizado. Além disso, é possível que mudanças em cascata sejam acionadas por eventos PropertyChanged. As alterações em cascata geralmente exigem que as atualizações sejam concluídas antes que a alteração em cascata seja segura para execução.
  • Nunca disparar um evento PropertyChanged se a propriedade não for alterada. Isso significa que você deve comparar os valores antigos e novos antes de gerar o evento PropertyChanged.
  • Nunca disparar um evento PropertyChanged durante o construtor de um view model ViewModel se você estiver inicializando uma propriedade. Os controles vinculados a dados na view View não estarão assinados para receber notificações de alteração neste momento.
  • Nunca disparar mais de um evento PropertyChanged com o mesmo argumento de nome de propriedade em uma única invocação síncrona de um método público de uma classe. Por exemplo, dada uma propriedade NumberOfItems cujo armazenamento de apoio é o campo _numberOfItems, se um método incrementa o _numberOfItems cinquenta vezes durante a execução de um loop, ele só deve gerar notificação de alteração de na propriedade NumberOfItems uma vez, depois que todo o trabalho estiver concluído. Para métodos assíncronos, gere o evento PropertyChanged para um determinado nome de propriedade em cada segmento síncrono de uma cadeia de continuação assíncrona.