{Binding #ElementName}是Avalonia中绑定同级或父级已命名控件属性的简洁语法,等价于{Binding PropertyName, ElementName=xxx},要求被引用控件有Name且在同一逻辑树层级,不适用于模板内或未加载控件。

在 Avalonia 中,{Binding #ElementName} 是一种简洁的语法,用于将一个控件的属性绑定到**同级或父级中已命名控件**的某个属性上,不需要额外配置 DataContext 或写冗长的绑定表达式。
这是最常用场景:两个控件处于同一容器内,目标控件用 Name 属性命名,源控件直接通过 #名称 引用。
Name(不是 x:Name,Avalonia 不支持 x:Name){Binding #xxx.PropertyName},比如 {Binding #txtInput.Text}
示例:
{Binding #xxx} 是 Avalonia 特有的简写,它和标准 WPF 风格的 {Binding PropertyName, ElementName=xxx} 完全等价。
{Binding #txtInput.Text} ⇔ {Binding Text, ElementName=txtInput}
这个语法看着简单,但容易因作用域理解偏差而失败。
TextBox 在 DataTemplate 或 ControlTemplate 内部,#xxx 默认查不到——模板内属于独立命名空间#xxx 引用父容器里定义的控件(除非父容器显式设了 Name,且子控件在同级逻辑树中)当目标控件不在同级,而在父级甚至祖先节点时,#xxx 就不管用了,得换用 $parent 系列语法:
{Binding $parent.Tag} → 绑定直接父控件的 Tag 属性{Binding $parent[1].Tag} → 绑定祖父控件(索引从 0 开始){Binding $parent[Border].Background} → 绑定最近的 Border 类型祖先的 Background这种写法不依赖 Name,靠类型或层级定位,更适合模板化或嵌套深的 UI 结构。
基本上就这些。#ElementName 绑定轻量直接,适合简单表单联动;遇到结构复杂或复用组件时,优先考虑 ViewModel 层统一管理状态,比跨控件硬绑更可控。
以上就是Avalonia中的{Binding #ElementName}怎么用 Avalonia元素名称绑定的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号