Avalonia笔记5-数据绑定

学习笔记:

1. 使用{Binding}标记拓展在XAML中进行绑定。通过绑定,所有数据上下文的变化都将自动更新到控件上。

<TextBlock Text="{Binding Name}"/>

 2. 绑定模式

可以通过指定{Binding}Mode来修改绑定的行为:

OneWay

源的变化自动传播到目标

TwoWay

源和目标的变化互相传播

OneTime

源的初始值会应用到目标,但后续的变化会被无视

OneWayToSource

目标的变化自动传播到源

Default

依据属性而定

3.绑定变化通知

private int _selectedParityIndex;
public int SelectParityIndex
{
    get => _selectedParityIndex;
    set => this.RaiseAndSetIfChanged(ref _selectedParityIndex, value);
}

4。与控件绑定

<TextBox Name="tb1">

<!-- 绑定到命名为“tb1”控件的Text属性 -->
<TextBlock Text="{Binding #tb1.Text}"/>

5. 绑定到父级

<Border Tag="Hello Avalonia!">
  <TextBlock Text="{Binding $parent.Tag}"/>
</Border>

<!-- 绑定到祖先级 -->
<Border Tag="Hello Avalonia!">
  <Border>
    <TextBlock Text="{Binding $parent[1].Tag}"/>
  </Border>
</Border>
<!-- 按类型绑定到祖先 -->
<Border Tag="Hello Avalonia!">
  <Decorator>
    <TextBlock Text="{Binding $parent[Border].Tag}"/>
  </Decorator>
</Border>

6. 绑定到转换器

<Window.Resources>
    <local:MyConverter x:Key="converter1"/>
</Window.Resources>

<TextBlock Text="{Binding Value, Converter={StaticResource converter1}}"/>

内置转换器 

转换器描述

StringConverters.IsNullOrEmpty

如果输入的字符串为null或empty,则返回true

StringConverters.IsNotNullOrEmpty

如果输入的字符串不为null或empty,则返回true

ObjectConverters.IsNull

如果输入为null,则返回true

ObjectConverters.IsNotNull

如果输入为null,则返回false

BoolConverters.And

一种多值转换器,如果所有输入均为true,则返回true

BoolConverters.Or

一种多值转换器,如果其中任意输入为true,则返回true

可以作为管道使用,也可以作为控制控件的现实和隐藏。

<!-- 控制是否隐藏 -->
<TextBlock Text="{Binding MyText}"
           IsVisible="{Binding MyText, Converter={x:Static StringConverters.IsNotNullOrEmpty}}"/>
<!-- 转换大小写 -->
<TextBlock Text="{Binding TheContent, 
    Converter={StaticResource textCaseConverter},
    ConverterParameter=lower}" />

7. 绑定到命令

<Button Command="{Binding DoTheThing}">Do the thing!</Button>
public ReactiveCommand<Unit, Unit> DoTheThing { get; }
public MainWindowViewModel()
{
    DoTheThing = ReactiveCommand.Create(RunTheThing);
}

void RunTheThing()
{
    // 此处执行命令的代码。
}

8. 绑定到方法

public void RunTheThing(string parameter)
{
    // 此处执行命令的代码。
}

可用CommandParameter传递参数。

如果需要从viewmodel里面触发CanExcute,则必须用一个或多个DependsOn属性来修饰它。

[DependsOn(nameof(IsTheThingEnabled))]
bool CanRunTheThing(/* CommandParameter */object parameter)
{
    return IsTheThingEnabled && parameter != null;
}

9.绑定到任务

public Task<string> MyAsyncText => GetTextAsync();

private async Task<string> GetTextAsync()
{
  await Task.Delay(1000);
  return "Hello from async operation";
}
<TextBlock Text="{Binding MyAsyncText^, FallbackValue='Wait a second'}" />

10.订阅属性的更改

var textBlock = new TextBlock();
var text = textBlock.GetObservable(TextBlock.TextProperty);
text.Subscribe(value => Console.WriteLine(value + " Changed"));

11.绑定到可观察对象

// 我们在这里使用Rx Subject,以便我们可以使用OnNext推送新值
var source = new Subject<string>();
var textBlock = new TextBlock();

// 将TextBlock.Text绑定到源
var subscription = textBlock.Bind(TextBlock.TextProperty, source);

// 将textBlock.Text设置为“hello”
source.OnNext("hello");
// 将textBlock.Text设置为“world!”
source.OnNext("world!");

// 终止绑定
subscription.Dispose();

12.控件模板中绑定

<TextBlock Name="tb" Text="{TemplateBinding Caption}"/>

<!-- 也能写成这样 -->
<TextBlock Name="tb" Text="{Binding Caption, RelativeSource={RelativeSource TemplatedParent}}"/>

TemplateBinding只接受单个属性而不是属性路径,因此如果要使用属性路径进行绑定,则必须使用第二种语法:

<!-- 这不起作用,因为TemplateBinding只接受单个属性 -->
<TextBlock Name="tb" Text="{TemplateBinding Caption.Length}"/>

<!-- 在这种情况下,必须使用此语法 -->
<TextBlock Name="tb" Text="{Binding Caption.Length, RelativeSource={RelativeSource TemplatedParent}}"/>

TemplateBinding仅支持单向绑定(OneWay) 、只能用于IStyledElement

<!-- 这不起作用,因为GeometryDrawing不是IStyledElement -->
<GeometryDrawing Brush="{TemplateBinding Foreground}"/>

<!-- 在这种情况下,必须使用此语法 -->
<GeometryDrawing Brush="{Binding Foreground, RelativeSource={RelativeSource TemplatedParent}}"/>

  • 15
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果您想在Avalonia应用程序中导入数据,可以按照以下步骤进行操作: 1. 确定您要导入的数据类型和格式。 2. 创建一个类来表示您的数据对象,并定义其属性。 3. 创建一个数据访问层来获取数据。您可以使用 ADO.NET 或 Entity Framework 等框架来访问数据库,或使用 Web API 来访问 Web 服务。 4. 在您的视图模型中创建一个集合属性来保存您的数据对象。 5. 在视图中使用绑定来显示您的数据。 以下是一个简单的示例,演示如何在Avalonia应用程序中导入数据: ```csharp //定义数据对象 public class Customer { public int Id { get; set; } public string Name { get; set; } public string Address { get; set; } } //创建数据访问层 public class CustomerRepository { public List<Customer> GetCustomers() { //使用 Entity Framework 或 ADO.NET 获取数据 //返回一个包含 Customer 对象的 List } } //在视图模型中创建一个集合属性 public class MainViewModel : ViewModelBase { private CustomerRepository _repository; public MainViewModel() { _repository = new CustomerRepository(); Customers = new ObservableCollection<Customer>(_repository.GetCustomers()); } public ObservableCollection<Customer> Customers { get; set; } } //在视图中使用绑定来显示数据 <ListBox Items="{Binding Customers}"> <ListBox.ItemTemplate> <DataTemplate> <StackPanel> <TextBlock Text="{Binding Name}"/> <TextBlock Text="{Binding Address}"/> </StackPanel> </DataTemplate> </ListBox.ItemTemplate> </ListBox> ``` 这只是一个简单的示例,您可以根据您的具体需求进行更改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值