- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
最近我读到一个IValueConverter
,它也继承自MarkupExtension
。它是这样的:
internal class BoolToVisibilityConverter : MarkupExtension, IValueConverter
{
private static BoolToVisibilityConverter converter;
public BoolToVisibilityConverter()
{
}
public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
{
if (value is bool)
{
if ((bool)value)
{
return Visibility.Visible;
}
}
return Visibility.Collapsed;
}
public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
{
if (value is Visibility)
{
Visibility visibility = (Visibility)value;
if (visibility == Visibility.Collapsed)
{
return false;
}
}
return true;
}
public override object ProvideValue(IServiceProvider serviceProvider)
{
return converter ?? (converter = new BoolToVisibilityConverter());
}
}
用法比看起来像:
<Button Content="Delete" Visibility="{Binding CanDelete, UpdateSourceTrigger=PropertyChanged, Converter={local:BoolToVisibilityConverter}"/>
我习惯于使用来自 Resource 的转换器,例如:
<loc:BoolToVisibilityConverter x:Key="BoolToVisibilityConverter"/>
...
<Button Content="Delete" Visibility="{Binding CanDelete, UpdateSourceTrigger=PropertyChanged, Converter={StaticResource BoolToVisibilityConverter}"/>
我现在的第一个问题是:什么是更好的方法?如果我使用 MarkupExtension-Version
有什么优势(除了用法更容易输入)?
我还看到了一个非常相似的实现,如下所示:
internal class BoolToVisibilityConverter : MarkupExtension, IValueConverter
{
public BoolToVisibilityConverter()
{
}
public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
{
if (value is bool)
{
if ((bool)value)
{
return Visibility.Visible;
}
}
return Visibility.Collapsed;
}
public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
{
if (value is Visibility)
{
Visibility visibility = (Visibility)value;
if (visibility == Visibility.Collapsed)
{
return false;
}
}
return true;
}
public override object ProvideValue(IServiceProvider serviceProvider)
{
return this;
}
}
如果我理解正确,第一个解决方案只创建此转换器的一个实例。第二个为每个 XAML 创建此转换器的新实例,对吗?
最佳答案
使用我从未见过在线使用的 MarkupExtension
的一个巨大优势是它可以让您将值传递给转换器,该转换器可以用作参数或返回值,例如:
public class CustomNullToVisibilityConverter : MarkupExtension, IValueConverter
{
public object NullValue { get; set; }
public object NotNullValue { get; set; }
public override object ProvideValue(IServiceProvider serviceProvider)
{
return this;
}
public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
{
if (value == null) return NullValue;
return NotNullValue;
}
public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
throw new NotImplementedException();
}
}
用法:
...
Visibility="{Binding Property,
Converter={cnv:CustomNullToVisibilityConverter
NotNullValue=Visible, NullValue=Collapsed}}" />
...
请务必在 .xaml
中引用转换器的命名空间。
编辑:
有一件事我忘了提,是的,你是对的,因为这种方法每次使用时都会创建一个新的转换器实例,这是一个缺点。
然而,没有什么可以阻止您将带有 MarkupExtension
的转换器添加到资源字典中 - 这样它只会被实例化一次。像这样:
<cnv:CustomNullToVisibilityConverter x:Key="NullToVisibilityConverter"
NotNullValue=Visible, NullValue=Collapsed />
...
Visibility="{Binding Property, Converter={StaticResource NullToVisibilityConverter}" />
...
关于c# - 带有 MarkupExtension 的 IValueConverter,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28501091/
有这样的 MarkupExtension public class Extension1 : MarkupExtension { private static int _counter = 0
将这个问题减少到最低限度,考虑这个 MarkupExtension 类...... public class ProblemStatement : MarkupExtension { priv
如何通过代码设置自定义 MarkupExtension? 您可以通过 Xaml 轻松设置 if。 Binding 和 DynamicResource 也是如此。 通过隐藏代码设置相同的值需要一些不同
我成功创建了我自己的 MarkupExtension,我将其命名为“GtringResource”并且运行良好,但在设计模式下却没有。 我在 ProvideValue(IServieProvider
我想创建自己的MarkupExtension(如Binding、TemplateBinding...) 我如何才能像在 WPF 中那样为通用应用程序做到这一点? 最佳答案 我有一个悲伤,但没有。 UW
我有一个简单的 UIElement,我想把它变成一个 MarkupExtension: [MarkupExtensionReturnType(typeof(FrameworkElement))] pu
我正在定制 MarkupExtension其中我需要来自 XAML 的非字符串参数来构造新对象。是否可以在 DataContext 中的字段上使用非字符串参数绑定(bind)?范围? 换句话说,我怎么
请帮助我如何创建一个 MarkupExtension 看起来像 wpf 的 StaticResource,我有: 我自己的类(class): public class Item{ public str
我正在尝试创建一个标记扩展,以简化为 WPF ResourceDictionary 的 Source 属性编写 URI。 问题的最小示例如下: CS: public class LocalResour
Fall Creators 更新 SDK 添加了一个 Markup Extension 类,很棒。 https://learn.microsoft.com/en-us/uwp/api/windows.
我试图最大限度地简化枚举到组合框的绑定(bind)。 在多个解决方案(ObjectDataProvider、Converter...)中,我选择了以下 MarkupExtension: public
我有一个工作 custom markup extension它以特定方式从 DataContext 中检索信息(对于这个问题不重要)。 一切都很好,直到我在不属于可视树或逻辑树的元素中使用此标记扩展。
我正在开发自定义标记扩展,其作用很简单: 在扩展构造函数参数(一种类型)上使用 System.Activator 并实例化它。 public class MyExtension : MarkupEx
我有 MyListYExtension 没有默认构造函数的标记扩展。因此它只能用构造函数语法创建。另一个 GetValueExtension 标记扩展试图确定所请求值的目标类型,以便它可以进行必要的转
我想实现值转换器来为 RenderTransform 指定点。在我只实现 IValueConverter 接口(interface)之前,它工作正常。我知道我可以实现 MarkupExtension
我正在使用 M-V-VM 模式 在我的虚拟机中我有这样的代码 public class ViewModel { public XmlDocument Document { ... }
我在查看我的一些旧代码时发现了一个混合的 IValueConverter/MarkupExtension 类。这让我想知道 ProvideValue 方法中的 IServiceProvider 是否真
最近我读到一个IValueConverter,它也继承自MarkupExtension。它是这样的: internal class BoolToVisibilityConverter : Markup
我有一个 CustomMarkupExtension 类。 Binding 正在工作 (!= null),但 BindingExpressionBase 始终为 null。 谁能解释一下为什么?我需要
如果您编写自己的 MarkupExtension,您可能会偶然发现 IServiceProvider serviceProvider 参数在设计时与运行时不同。例如,您无法获取 IRootObject
我是一名优秀的程序员,十分优秀!