상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - MVVM에서 뷰모델의 속성을 동적으로 변경하는 방법은 무엇인가요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
MVVM(모델-뷰-뷰모델) 패턴은 UI와 비즈니스 로직을 분리하여 코드의 <a href='https://sangseek.com/sangseeks/유지보수성/ko'>유지보수성</a>과 재사용성을 높이는 아키텍처 패턴입니다. MVVM에서 뷰모델(ViewModel)은 뷰(View)와 모델(Model) 간의 중재자 역할을 하며, 뷰의 상태를 관리하고 데이터 <a href='https://sangseek.com/sangseeks/바인딩/ko'>바인딩</a>을 통해 뷰에 데이터를 제공합니다. 뷰모델의 속성을 동적으로 변경하는 방법은 여러 가지가 있으며, 이 과정에서 데이터 바인딩을 활용하여 UI를 자동으로 업데이트할 수 있습니다. 1. INotifyPropertyChanged 인터페이스 구현 MVVM에서 뷰모델의 속성을 동적으로 변경하려면 `INotifyPropertyChanged` 인터페이스를 구현해야 합니다. 이 인터페이스는 속성이 변경될 때 뷰에 알릴 수 있는 메커니즘을 제공합니다. 다음은 `INotifyPropertyChanged`를 구현한 간단한 예제입니다. ```csharp using System.ComponentModel; public class MyViewModel : INotifyPropertyChanged { private string _myProperty; public string MyProperty { get { return _myProperty; } set { if (_myProperty != value) { _myProperty = value; OnPropertyChanged(nameof(MyProperty)); } } } public event PropertyChangedEventHandler PropertyChanged; protected virtual void OnPropertyChanged(string propertyName) { PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName)); } } ``` 위의 코드에서 `MyProperty` 속성이 변경될 때 `OnPropertyChanged` 메서드를 호출하여 뷰에 변경 사항을 알립니다. 2. <a href='https://sangseek.com/sangseeks/ObservableCollection/ko'>ObservableCollection</a> 사용 리스트와 같은 컬렉션을 동적으로 변경해야 할 경우, `ObservableCollection<T>`를 사용하는 것이 좋습니다. `ObservableCollection`은 항목이 추가되거나 제거될 때 자동으로 UI에 알리는 기능을 제공합니다. ```csharp using System.Collections.ObjectModel; public class MyViewModel : INotifyPropertyChanged { public ObservableCollection<string> Items { get; set; } public MyViewModel() { Items = new ObservableCollection<string>(); } public void AddItem(string item) { Items.Add(item); } } ``` 위의 예제에서 `Items` 컬렉션에 항목을 추가하면 UI가 자동으로 업데이트됩니다. 3. Command 패턴 사용 MVVM에서 사용자 인터페이스의 동작을 처리하기 위해 Command 패턴을 사용하는 것이 일반적입니다. `<a href='https://sangseek.com/sangseeks/ICommand/ko'>ICommand</a>` 인터페이스를 구현하여 버튼 클릭과 같은 이벤트를 처리할 수 있습니다. ```csharp using System.Windows.Input; public class RelayCommand : ICommand { private readonly Action<object> _execute; private readonly Predicate<object> _canExecute; public RelayCommand(Action<object> execute, Predicate<object> canExecute = null) { _execute = execute; _canExecute = canExecute; } public event EventHandler CanExecuteChanged; public bool CanExecute(object parameter) { return _canExecute == null || _canExecute(parameter); } public void Execute(object parameter) { _execute(parameter); } public void RaiseCanExecuteChanged() { CanExecuteChanged?.Invoke(this, EventArgs.Empty); } } ``` 뷰모델에서 `RelayCommand`를 사용하여 버튼 클릭 시 속성을 변경할 수 있습니다. ```csharp public class MyViewModel : INotifyPropertyChanged { public ICommand ChangePropertyCommand { get; } private string _myProperty; public string MyProperty { get { return _myProperty; } set { if (_myProperty != value) { _myProperty = value; OnPropertyChanged(nameof(MyProperty)); } } } public MyViewModel() { ChangePropertyCommand = new RelayCommand(ChangeProperty); } private void ChangeProperty(object parameter) { MyProperty = "New Value"; } } ``` 4. 데이터 바인딩 MVVM의 핵심은 데이터 바인딩입니다. XAML에서 뷰모델의 속성을 바인딩하여 UI를 자동으로 업데이트할 수 있습니다. ```xml <TextBox Text="{Binding MyProperty, UpdateSourceTrigger=PropertyChanged}" /> <Button Command="{Binding ChangePropertyCommand}" Content="Change Property" /> ``` 위의 XAML 코드에서 `TextBox`는 `MyProperty` 속성과 바인딩되어 있으며, `Button`은 `ChangePropertyCommand`와 바인딩되어 있습니다. 버튼을 클릭하면 `MyProperty`가 변경되고, 이로 인해 `TextBox`의 내용이 자동으로 업데이트됩니다. 결론 MVVM에서 뷰모델의 속성을 동적으로 변경하는 방법은 `INotifyPropertyChanged` 인터페이스를 구현하고, `ObservableCollection`을 사용하며, Command 패턴을 활용하는 것입니다. 이러한 방법을 통해 UI와 비즈니스 로직을 효과적으로 분리하고, 데이터 바인딩을 통해 UI를 자동으로 업데이트할 수 있습니다. MVVM 패턴을 잘 활용하면 코드의 유지보수성과 재사용성을 높일 수 있습니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기