0

我在使用 gridview 和其中的组合框时遇到了一些问题。

这是我的 ListView 控件的代码:

<ListView Height="139" HorizontalAlignment="Left" Margin="10,158,0,0" Name="lvAppointment" VerticalAlignment="Top" Width="250" MinWidth="350">
<ListView.View>
    <GridView>
        <GridViewColumn Header="Appointment" Width="120">
            <GridViewColumn.CellTemplate>
                <DataTemplate>
                    <DatePicker SelectedDate="{Binding Path=Appointment}"/>
                </DataTemplate>
            </GridViewColumn.CellTemplate>
        </GridViewColumn>
        <GridViewColumn Header="Type" Width="170">
            <GridViewColumn.CellTemplate>
                <DataTemplate>
                    <ComboBox ???/>
                </DataTemplate>
            </GridViewColumn.CellTemplate>
        </GridViewColumn>
        <GridViewColumn Header="Done" Width="50">
            <GridViewColumn.CellTemplate>
                <DataTemplate>
                    <CheckBox IsChecked="{Binding Path=Done}" IsThreeState="False"/>
                </DataTemplate>
            </GridViewColumn.CellTemplate>
        </GridViewColumn>
    </GridView>
</ListView.View>

我正在使用以下代码通过 c# 从 sql ce 数据库中填充列表

using (SqlCeCommand sqlCeAppointment = new SqlCeCommand("SELECT appid,appointment,done,apptype.type FROM appointment INNER JOIN apptype ON appointment.refatid = apptype.atid WHERE refeventid = @eventid;", sqlCeConn))
    {
        sqlCeAppointment.Parameters.AddWithValue("@eventid", ((cListEventItem)lvEvent.SelectedItems[0]).id);
        using (SqlCeDataReader sqlCeAppointmentReader = sqlCeAppointment.ExecuteReader())
        {
            lvAppointment.Items.Clear();

            while (sqlCeAppointmentReader.Read())
            {
                lvAppointment.Items.Add(new cListAppointmentItem { id = sqlCeAppointmentReader.GetGuid(sqlCeTerminReader.GetOrdinal("appid")), Appointment = sqlCeAppointmentReader.GetDateTime(sqlCeTerminReader.GetOrdinal("appointment")), Type = sqlCeAppointmentReader.GetString(sqlCeTerminReader.GetOrdinal("type")), Done = sqlCeAppointmentReader.GetByte(sqlCeTerminReader.GetOrdinal("done")) });
            }
        }
    }

我可以很好地填充列表。但我希望“类型”成为一个组合框,以便用户可以选择约会的适当类型(它是连接到事件的约会列表)。此组合框应填充 sql ce 数据库 (apptype) 表中的数据。该表不是静态的,用户可以从该列表中添加和删除项目。

我尝试了几种通过谷歌找到的方法,但都失败了。我想我在理解这是如何工作/应该如何工作时遇到问题。

我希望有一个人可以帮助我 :(

提前致谢

4

2 回答 2

0

我建议在 MainViewModel 上获取约会类型列表。然后将 的 绑定ItemsSourceComboBox该 List 并将 绑定SelectedItem到 AppointmentItem 类型。

<UserControl x:Name="TheUserControl">
    <ListView>
        <GridView>
            <GridViewColumn Header="Type" Width="170">
                <GridViewColumn.CellTemplate>
                    <DataTemplate>
                        <ComboBox ItemsSource="{Binding ElementName=TheUserControl, Path=AppointmentTypes}"
                                  SelectedItem="{Binding Path=Type}"/>
                    </DataTemplate>
                </GridViewColumn.CellTemplate>
            </GridViewColumn>
        </GridView>
    </ListView>
</UserControl>
于 2012-06-19T09:21:22.417 回答
0

您可以通过定义 ObservableCollection 类型的属性来做到这一点。如果集合的数据类型是字符串,那么您可以将其定义为:

  public ObservableCollection<string> Types
        {
            get
            {
                ObservableCollection<string> _types = new ObservableCollection<string>();
                _types.Add("value1");
                _types.Add("value2");
                _types.Add("value3");
                return _types;
            }

        }

在您的 XAML 中,您可以将其绑定为:

 <ComboBox VerticalAlignment="Top"  HorizontalAlignment="Left" ItemsSource="{Binding Path=Types}" SelectedItem="{Binding MainViewModel.Type,Mode=TwoWay}" SelectedValue="{Binding SelectedValue}"  Width="300"  ></ComboBox>
于 2017-07-02T12:46:11.253 回答