WPF RichTextBox 문서에 대한 데이터 바인딩을 구현하려고 할 때 두 가지 주요 솔루션이 있습니다. 즉, 종속 속성이 있는 사용자 정의 RichTextBox 파생 클래스를 생성하거나 "프록시" 메서드를 사용하는 것입니다. 그러나 이러한 방법에는 여전히 개선의 여지가 있습니다.
첨부된 속성을 사용한 단순화된 솔루션
더 간단한 대안은 추가 DocumentXaml
속성을 만드는 것입니다. 이 속성을 사용하면 RichTextBox를 문서에 쉽게 바인딩할 수 있습니다. 사용방법은 다음과 같습니다.
<textbox text="{Binding FirstName}"></textbox><textbox text="{Binding LastName}"></textbox><richtextbox local:richtextboxhelper.documentxaml="{Binding Autobiography}"></richtextbox>
업적
DocumentXaml
연결된 속성의 구현은 속성을 설정할 때 XAML(또는 RTF)을 새 FlowDocument에 로드하는 것과 관련이 있습니다. 대신 FlowDocument가 변경되면 속성 값이 업데이트됩니다.
다음 코드는 구현을 캡슐화합니다.
public class RichTextBoxHelper : DependencyObject { public static string GetDocumentXaml(DependencyObject obj) => (string)obj.GetValue(DocumentXamlProperty); public static void SetDocumentXaml(DependencyObject obj, string value) => obj.SetValue(DocumentXamlProperty, value); public static readonly DependencyProperty DocumentXamlProperty = DependencyProperty.RegisterAttached("DocumentXaml", typeof(string), typeof(RichTextBoxHelper), new FrameworkPropertyMetadata { BindsTwoWayByDefault = true, PropertyChangedCallback = (obj, e) => { var richTextBox = (RichTextBox)obj; // 将XAML解析为文档 var doc = new FlowDocument(); var range = new TextRange(doc.ContentStart, doc.ContentEnd); range.Load(new MemoryStream(Encoding.UTF8.GetBytes(GetDocumentXaml(richTextBox))), DataFormats.Xaml); // 设置文档 richTextBox.Document = doc; // 文档更改时更新源 range.Changed += (obj2, e2) => { if (richTextBox.Document == doc) { MemoryStream buffer = new MemoryStream(); range.Save(buffer, DataFormats.Xaml); SetDocumentXaml(richTextBox, Encoding.UTF8.GetString(buffer.ToArray())); } }; } }); }
이 방법은 복잡한 솔루션이나 상업적 제어 없이 RichTextBox 문서를 바인딩할 수 있는 편리한 옵션을 제공합니다.
위 내용은 WPF RichTextBox 문서에 대한 데이터 바인딩을 단순화하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!