1
我是新的WPF/EF和tring绑定两个组合框相互。C#绑定选择儿童组合框
我的代码来启动该实体:
private ShipperDBEntities shipper;
public EnterIndicator()
{
InitializeComponent();
shipper = new ShipperDBEntities();
ReLoad();
}
在我刷新子,我开始查询使用LINQ该实体。 首先,我的IndicatorComboBox,cartype(船,汽车,不显眼的chaising汽车和更多...类型..)。 第二个组合框包含所有类型的定义。但是当我选择了上面的指标之一时,第二个TypeComboBox应该选择合适的车型。汽车的类型在数据库中定义。 这里是代码查询:
DataContext = null;
var query = (from Fahrzeuges in shipper.Fahrzeuges
join typen in shipper.Fahrzeugtypens on Fahrzeuges.Fahrzeugtyp equals
typen.FahrzeugTyp_ID
where
Fahrzeuges.Versandunternehman.Versandunternehmen == LieferantenName
select new
{
Fahrzeuges.Kennzeichen,
Fahrzeuges.Fahrzeug_ID,
typen.FahrzeugTyp
});
DataContext = query.ToList();
FahrzeugTypBox.ItemsSource = (from Fahrzeugtypens in shipper.Fahrzeugtypens
select new
{
FahrzeugTyp_ID = Fahrzeugtypens.FahrzeugTyp_ID,
FahrzeugTyp = Fahrzeugtypens.FahrzeugTyp
}).ToList();
KennzeichenBox.SelectedIndex = 0;
我想我可以解决这个问题,通过使用正确的XAML。 这是xaml的代码(但我真的不知道如何)。
<ComboBox Grid.Row="1" Grid.Column="1" ItemsSource="{Binding}" SelectedValuePath="Fahrzeug_ID" DisplayMemberPath="Kennzeichen" VerticalAlignment="Top" Name="KennzeichenBox" Height="25" SelectionChanged="KennzeichenBox_SelectionChanged"/>
<ComboBox Grid.Row="3" IsSynchronizedWithCurrentItem="True"
Grid.Column="1" ItemsSource="{Binding}"
SelectedValuePath="FahrzeugTyp_id"
DisplayMemberPath="FahrzeugTyp"
SelectedValue="{Binding SelectedItem.FahrzeugTyp,ElementName=KennzeichenBox}"
VerticalAlignment="Top"
Name="FahrzeugTypBox" Height="25"/>
我开始尝试通过使用SelectedValue = {Binding}从第一个组合框的选择尝试解决方案。
有什么建议吗?谢谢!然后
DataContext = this;
public List<dynamic> Fahrzeuges { get; set; }
public List<dynamic> Typen { get; set; }
Fahrzeuges = new List<dynamic>(from Fahrzeuges in shipper.Fahrzeuges
join typen in shipper.Fahrzeugtypens on
Fahrzeuges.Fahrzeugtyp equals
typen.FahrzeugTyp_ID
where Fahrzeuges.Versandunternehman.Versandunternehmen == LieferantenName
select new
{
Kennzeichen = Fahrzeuges.Kennzeichen,
Fahrzeug_ID = Fahrzeuges.Fahrzeug_ID,
FahrzeugTyp = typen.FahrzeugTyp
});
Typen = new List<dynamic>(from Fahrzeugtypens in shipper.Fahrzeugtypens
select new
{
FahrzeugTyp_ID = Fahrzeugtypens.FahrzeugTyp_ID,
FahrzeugTyp = Fahrzeugtypens.FahrzeugTyp
});
在XAML:
您好,感谢您的回复。我遇到了一个问题,将选择结果转换为动态通用列表。 – rkn53940
编辑了答案。 –