WPF中如何將ListViewItem雙擊事件綁定到Command


今天的博客將介紹如何實現ListViewItem雙擊事件綁定到ViewModel中的Command。實現方法借助了Style中的EventSetter,請看下面的詳細代碼:

<ListView ItemsSource="{Binding Users}">
    <ListView.ItemTemplate>
        <DataTemplate>
            <Grid>
                <Grid.ColumnDefinitions>
                    <ColumnDefinition Width="*" />
                    <ColumnDefinition Width="2*" />
                    <ColumnDefinition Width="3*" />
                </Grid.ColumnDefinitions>

                <TextBlock Text="{Binding Name}" VerticalAlignment="Center" HorizontalAlignment="Center" />

                <TextBlock Grid.Column="1" Text="{Binding Birthday}" VerticalAlignment="Center" HorizontalAlignment="Center" />

                <TextBlock Grid.Column="2" Text="{Binding Address}" VerticalAlignment="Center" HorizontalAlignment="Center" />
            </Grid>
        </DataTemplate>
    </ListView.ItemTemplate>
    <ListView.ItemContainerStyle>
        <Style TargetType="{x:Type ListViewItem}">
            <Style.Setters>
                <EventSetter Event="MouseDoubleClick" Handler="OnListViewItemDoubleClick" />
            </Style.Setters>
        </Style>
    </ListView.ItemContainerStyle>
</ListView>

在Code Behind中,

        private void OnListViewItemDoubleClick(object sender, MouseButtonEventArgs e)
        {
            var vm = this.DataContext as MainViewModel; vm.EditCommand.Execute();
        }

具體的ViewModel中執行需要的操作即可。這樣不會打破MVVM模式。

    class MainViewModel
    {
        private ObservableCollection<User> _users;
        public ObservableCollection<User> Users
        {
            get
            {
                if(_users == null)
                {
                    _users = new ObservableCollection<User>();
                }

                return _users;
            }
        }

        public DelegateCommand EditCommand { get; private set; }

        public MainViewModel()
        {
            Users.Add(new User() { Name = "Tom", Address = "WUXI IPARK", Birthday = new DateTime(2000,1,1) });

            Users.Add(new User() { Name = "Jack", Address = "WUXI IPARK", Birthday = new DateTime(2000, 1, 1) });

            Users.Add(new User() { Name = "Jerry", Address = "WUXI IPARK", Birthday = new DateTime(2000, 1, 1) });

            Users.Add(new User() { Name = "Hellen", Address = "WUXI IPARK", Birthday = new DateTime(2000, 1, 1) });

            EditCommand = new DelegateCommand(Edit);
        }

        private void Edit() { System.Diagnostics.Debug.WriteLine("MouseDoubleClick Command."); }
    }

通過上面的方式就很簡單的將ListView中的MouseDoubleClick事件綁定到Command上。

感謝您的閱讀,代碼點擊這里下載。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM