WPF DataGrid의 열 동적 바인딩
WPF DataGrid의 Columns 속성은 읽기 전용이므로 가변 개수의 열이 있는 데이터를 프로그래밍 방식으로 바인딩하려고 할 때 문제가 발생합니다.
다음 시나리오를 고려해보세요.
<code class="language-csharp">class Data { public IList<ColumnDescription> ColumnDescriptions { get; set; } public string[][] Rows { get; set; } }</code>
이 데이터를 DataGrid에 표시하려면 열을 동적으로 생성해야 합니다.
<code class="language-csharp">for (int i = 0; i < data.ColumnDescriptions.Count; i++) { dataGrid.Columns.Add(new DataGridTextColumn { Header = data.ColumnDescriptions[i].Name, Binding = new Binding(string.Format("[{0}]", i)) }); }</code>
이 코드를 XAML 파일의 데이터 바인딩으로 바꿀 수 있나요?
해결책: BindableColumns 첨부 속성
Columns 속성은 여전히 읽기 전용이지만 BindableColumns라는 추가 속성을 생성할 수 있습니다.
<code class="language-csharp">public class DataGridColumnsBehavior { public static readonly DependencyProperty BindableColumnsProperty = DependencyProperty.RegisterAttached("BindableColumns", typeof(ObservableCollection<DataGridTextColumn>), typeof(DataGridColumnsBehavior), new UIPropertyMetadata(null, BindableColumnsPropertyChanged)); // ... }</code>
그런 다음 XAML에서 BindableColumns 속성을 DataGridColumn 개체의 ObservableCollection에 바인딩할 수 있습니다.
<code class="language-xml"><DataGrid Name="dataGrid"> local:DataGridColumnsBehavior.BindableColumns="{Binding ColumnCollection}" AutoGenerateColumns="False" ... /></code>
사용방법
BindableColumns 동작을 사용하려면 DataGridColumn 개체의 ObservableCollection을 정의하세요.
<code class="language-csharp">public ObservableCollection<DataGridTextColumn> ColumnCollection { get; private set; }</code>
CollectionChanged 이벤트를 통해 열을 동적으로 업데이트합니다.
<code class="language-csharp">columns.CollectionChanged += (sender, e2) => { // ... };</code>
이 해결 방법을 사용하면 읽기 전용 열 속성을 수정하지 않고도 DataGrid에서 열의 데이터 바인딩을 허용할 수 있습니다.
위 내용은 XAML을 사용하여 WPF DataGrid에 열을 동적으로 바인딩하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!