상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
궁금한 상식 보기
사카린이 식욕에 미치는 영향은 무엇인가요?
퍼그의 털은 어떤 특징이 있나요?
설탕의 섭취 권장량은 얼마인가요?
스테비아의 품종은 몇 가지가 있나요?
글리세롤이 신경계에 미치는 영향은 무엇인가요?
글리세롤이 체중 감소에 미치는 영향은 무엇인가요?
루아에서 변수를 선언하는 방법은 무엇인가요?
루아에서 `math.ceil` 함수는 어떻게 작동하나요?
루아에서 `string.gmatch` 함수는 어떻게 작동하나요?
질산은 어떤 산업에서 주로 사용되나요?
질산의 안전한 사용을 위한 지침은 무엇인가요?
아스파탐의 사용이 증가하면서 나타나는 사회적 변화는 무엇인가요?
Previous
Next
수정하기 - MVVM에서 뷰모델의 속성을 변경하는 방법은 무엇인가요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
<a href='https://sangseek.com/sangseeks/MVVM/ko'>MVVM</a> (Model-View-ViewModel) 패턴은 주로 <a href='https://sangseek.com/sangseeks/WPF/ko'>WPF</a>, Xamarin, UWP와 같은 XAML 기반의 애플리케이션에서 사용되는 아키텍처 패턴입니다. MVVM의 핵심은 뷰(View)와 비즈니스 로직(ViewModel) 간의 분리를 통해 코드의 재사용성과 유지보수성을 높이는 것입니다. 이 패턴에서 뷰모델(ViewModel)은 뷰의 상태와 동작을 정의하며, 뷰와 모델 간의 중재자 역할을 합니다. 뷰모델의 속성을 변경하는 방법은 여러 가지가 있으며, 주로 `INotify<a href='https://sangseek.com/sangseeks/PropertyChanged/ko'>PropertyChanged</a>` 인터페이스를 통해 이루어집니다. 이 인터페이스는 속성이 변경될 때 뷰에 알릴 수 있는 메커니즘을 제공합니다. 아래에서는 뷰모델의 속성을 변경하는 방법에 대해 자세히 설명하겠습니다. 1. INotifyPropertyChanged 인터페이스 구현 뷰모델 클래스는 `INotifyPropertyChanged` 인터페이스를 구현해야 합니다. 이 인터페이스는 `PropertyChanged` 이벤트를 포함하고 있으며, 속성이 변경될 때 이 이벤트를 발생시켜 뷰에 알립니다. ```csharp using System.ComponentModel; public class MyViewModel : INotifyPropertyChanged { public event PropertyChangedEventHandler PropertyChanged; protected void OnPropertyChanged(string propertyName) { PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName)); } private string _myProperty; public string MyProperty { get => _myProperty; set { if (_myProperty != value) { _myProperty = value; OnPropertyChanged(nameof(MyProperty)); } } } } ``` 2. 속성 변경 뷰모델의 속성을 변경할 때는 해당 속성의 setter에서 `OnPropertyChanged` 메서드를 호출하여 속성이 변경되었음을 알립니다. 위의 예제에서 `MyProperty` 속성이 변경되면 `OnPropertyChanged`가 호출되어 뷰에 변경 사항이 전파됩니다. 3. 데이터 바인딩 뷰(View)에서는 XAML을 사용하여 뷰모델의 속성과 바인딩할 수 있습니다. 예를 들어, 다음과 같이 XAML에서 `MyProperty`를 바인딩할 수 있습니다. ```xml <Window x:Class="MyApp.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" Title="MainWindow" Height="350" Width="525"> <<a href='https://sangseek.com/sangseeks/Grid/ko'>Grid</a>> <<a href='https://sangseek.com/sangseeks/TextBox/ko'>TextBox</a> Text="{Binding MyProperty, UpdateSourceTrigger=PropertyChanged}" /> </Grid> </Window> ``` 4. 뷰모델 인스턴스 설정 뷰모델 인스턴스는 뷰의 DataContext로 설정되어야 합니다. 이렇게 하면 뷰에서 뷰모델의 속성에 접근할 수 있습니다. ```csharp public partial class MainWindow : Window { public MainWindow() { InitializeComponent(); DataContext = new MyViewModel(); } } ``` 5. <a href='https://sangseek.com/sangseeks/커맨드/ko'>커맨드</a> 사용 MVVM 패턴에서는 사용자 인터페이스의 동작을 처리하기 위해 커맨드를 사용합니다. 커맨드는 뷰모델에서 정의되며, 뷰에서 버튼 클릭과 같은 이벤트에 바인딩할 수 있습니다. 커맨드를 사용하여 뷰모델의 속성을 변경할 수 있습니다. ```csharp using System.Windows.Input; public class MyViewModel : INotifyPropertyChanged { // ... (INotifyPropertyChanged 구현) private string _myProperty; public string MyProperty { get => _myProperty; set { if (_myProperty != value) { _myProperty = value; OnPropertyChanged(nameof(MyProperty)); } } } public ICommand ChangePropertyCommand { get; } public MyViewModel() { ChangePropertyCommand = new RelayCommand(ChangeProperty); } private void ChangeProperty() { MyProperty = "새로운 값"; } } ``` 6. XAML에서 커맨드 바인딩 XAML에서 버튼 클릭 시 커맨드를 호출하도록 설정할 수 있습니다. ```xml <Button Content="Change Property" Command="{Binding ChangePropertyCommand}" /> ``` 결론 MVVM 패턴에서 뷰모델의 속성을 변경하는 방법은 `INotifyPropertyChanged` 인터페이스를 구현하고, 속성의 setter에서 `OnPropertyChanged` 메서드를 호출하여 뷰에 변경 사항을 알리는 것입니다. 또한, 커맨드를 사용하여 사용자 인터페이스의 동작을 처리하고, 뷰와 뷰모델 간의 데이터 바인딩을 통해 상호작용을 구현할 수 있습니다. 이러한 방식으로 MVVM 패턴을 활용하면 애플리케이션의 구조를 명확하게 유지하고, 코드의 재사용성과 유지보수성을 높일 수 있습니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기