如何在C#UWP中访问ListView中的ToggleSwitch实例?

时间:2018-04-04 19:38:27

标签: c# listview uwp toggle toggleswitch

我打开了问题here,但我们无法找到问题的解决方案。我决定创建一个新的问题,因为我们得出了一些假设,而前一个问题并没有提到真正的问题(我们认为这是绑定的问题,但正如你将会读到的那样)。

简而言之,我有一个ListView,列表中的数据名为jointList。 该列表运行良好,并且包含所有必需的数据。 (我查了一下)

在ListView的每一行上,我放了一个ToggleSwitch(在xaml中),然后我尝试对每个开关做一些事情。

每个开关应对应同一行的数据。

我创建了Toggled事件,应该适用于所有这样的toggleSwitches:

private void ToggleSwitch_Toggled(object sender, RoutedEventArgs e)
    {

        foreach (var product in jointList)
        {

            if (product.IsOn == true)
            {
                ToggleTest.Text = product.ProductId.ToString(); // this is for testing only, later I would do something with the data retrieved
                ToggleTest.Visibility = Visibility.Visible;
            }
            else
            {
                ToggleTest.Visibility = Visibility.Collapsed;
            }

        }

    }

但这只是一个toggleSwitch工作。它是与列表中最后添加的产品相对应的开关(我猜它是指向最后一个Id)。其他开关没有返回任何内容,就好像方法没有正确地遍历列表或者只是连接了一个交换机一样。

那么,当我尝试使用一个Toggled事件时,是否可以启动并运行所有交换机?

2 个答案:

答案 0 :(得分:1)

这是一个显示单向的样本。

在此示例中,我们有以下产品视图模型:

public class Product : INotifyPropertyChanged
{
    private string _name;

    public string Name
    {
        get => _name;
        set
        {
            if (value == _name) return;
            _name = value;
            OnPropertyChanged();
        }
    }

所以只需一个名字属性。

然后我们在MainPage中创建了一系列产品:

    private void FrameworkElement_OnLoaded(object sender, RoutedEventArgs e)
    {
        var items = new ObservableCollection<Product>();
        for (int i = 0; i < 9; i++)
        {
            items.Add(new Product($"item {i}"));
        }

        this.Items.ItemsSource = items;
    }

创建视图的XAML:

    <ListView Loaded="FrameworkElement_OnLoaded" x:Name="Items">
        <ListView.ItemTemplate>
            <DataTemplate>
                <Grid>
                    <Grid.ColumnDefinitions>
                        <ColumnDefinition/>
                        <ColumnDefinition/>
                    </Grid.ColumnDefinitions>

                    <TextBlock x:Name="RowContent" Text="{Binding Name}"/>
                    <ToggleSwitch x:Name="Toggle" Grid.Column="1" Toggled="Toggle_OnToggled"/>
                </Grid>
            </DataTemplate>
        </ListView.ItemTemplate>
    </ListView>

结果:

Starting situation

现在我们想要在用户切换开关时更改文本。这是在Toggle_OnToggled-event处理程序中完成的:

    private void Toggle_OnToggled(object sender, RoutedEventArgs e)
    {
        var toggle = (ToggleSwitch) sender;

        var dataContext = ((Grid)toggle.Parent).DataContext;
        var dataItem = (Product) dataContext;

        dataItem.Name = $"Toggled {toggle.IsOn}";
    }

经过几次切换之后:

Toggle

答案 1 :(得分:0)

Mikael Koskinen已经解决了我的问题。

除了OnToggled事件处理程序的最后一点之外,我的大多数代码都是正确的并且与他的解决方案完全相同。 这是工作和正确的处理程序:

private void Toggle_OnToggled(object sender, RoutedEventArgs e)
    {
        var toggle = (ToggleSwitch)sender;

        var dataContext = ((Grid)toggle.Parent).DataContext;
        var dataItem = (ScheduleList)dataContext;

        ToggleTest.Text = dataItem.ProductId;
    }

我之前的处理程序版本没有包含重要的位,即dataContext和dataItem。

它现在就像一个魅力。