如何根据 ComboBox 中选择的项目将 TextBox 设置为只读?
How to make a TextBox read-only based on the item selected in the ComboBox?
如果你能帮助我,我将不胜感激,谢谢!
这是XAML
<ComboBox Margin="8" Name="cmbox" SelectionChanged="cmbox_SelectionChanged" >
<ComboBoxItem IsSelected="True">ESCALONADO</ComboBoxItem>
<ComboBoxItem>INTEGRAL</ComboBoxItem>
</ComboBox>
<TextBox IsReadOnly="{Binding Testcmb}" Grid.Column="1" Margin="8"/>
下面是一小段代码
我尝试根据组合框上的所选项目来归因于 属性 Testcmb 的值,然后将绑定到文本框以将其转换为 IsReadOnly="true"。语法正确吗?
private void cmbox_SelectionChanged(object sender, SelectionChangedEventArgs e)
{
if(cmbox.SelectedIndex > 0)
{
(Object).Testcmb = true;
}
else
{
(Object).Testcmb = false;
}
}
private bool _testcmb;
public bool Testcmb
{
get { return _testcmb; }
set
{
if (this._testcmb != value)
{
this._testcmb = value;
this.NotifyPropertyChanged("Testcmb");
};
}
}
public event PropertyChangedEventHandler PropertyChanged;
public void NotifyPropertyChanged(string propName)
{
if (PropertyChanged != null)
{
PropertyChanged(this, new PropertyChangedEventArgs(propName));
}
}
欢迎来到 Whosebug。您的语法确实是正确的,但是您将数据绑定与事件处理程序混合在一起,所有这些都在视图的代码隐藏中。
你可以使用 Style
做你想做的事,这对我来说更清楚这种 UI 逻辑。这是仅 XAML 的解决方案:
<ComboBox x:Name="cbox">
<ComboBoxItem IsSelected="True" Content="ESCALONADO"/>
<ComboBoxItem Content="INTEGRAL" />
</ComboBox>
<TextBox Text="Some text...">
<TextBox.Style>
<Style TargetType="TextBox">
<Setter Property="IsReadOnly" Value="True" />
<Style.Triggers>
<DataTrigger Binding="{Binding SelectedIndex, ElementName=cbox}" Value="0">
<Setter Property="IsReadOnly" Value="False" />
</DataTrigger>
</Style.Triggers>
</Style>
</TextBox.Style>
</TextBox>
如果你能帮助我,我将不胜感激,谢谢!
这是XAML
<ComboBox Margin="8" Name="cmbox" SelectionChanged="cmbox_SelectionChanged" >
<ComboBoxItem IsSelected="True">ESCALONADO</ComboBoxItem>
<ComboBoxItem>INTEGRAL</ComboBoxItem>
</ComboBox>
<TextBox IsReadOnly="{Binding Testcmb}" Grid.Column="1" Margin="8"/>
下面是一小段代码
我尝试根据组合框上的所选项目来归因于 属性 Testcmb 的值,然后将绑定到文本框以将其转换为 IsReadOnly="true"。语法正确吗?
private void cmbox_SelectionChanged(object sender, SelectionChangedEventArgs e)
{
if(cmbox.SelectedIndex > 0)
{
(Object).Testcmb = true;
}
else
{
(Object).Testcmb = false;
}
}
private bool _testcmb;
public bool Testcmb
{
get { return _testcmb; }
set
{
if (this._testcmb != value)
{
this._testcmb = value;
this.NotifyPropertyChanged("Testcmb");
};
}
}
public event PropertyChangedEventHandler PropertyChanged;
public void NotifyPropertyChanged(string propName)
{
if (PropertyChanged != null)
{
PropertyChanged(this, new PropertyChangedEventArgs(propName));
}
}
欢迎来到 Whosebug。您的语法确实是正确的,但是您将数据绑定与事件处理程序混合在一起,所有这些都在视图的代码隐藏中。
你可以使用 Style
做你想做的事,这对我来说更清楚这种 UI 逻辑。这是仅 XAML 的解决方案:
<ComboBox x:Name="cbox">
<ComboBoxItem IsSelected="True" Content="ESCALONADO"/>
<ComboBoxItem Content="INTEGRAL" />
</ComboBox>
<TextBox Text="Some text...">
<TextBox.Style>
<Style TargetType="TextBox">
<Setter Property="IsReadOnly" Value="True" />
<Style.Triggers>
<DataTrigger Binding="{Binding SelectedIndex, ElementName=cbox}" Value="0">
<Setter Property="IsReadOnly" Value="False" />
</DataTrigger>
</Style.Triggers>
</Style>
</TextBox.Style>
</TextBox>