C# 仅当选择了“WPF MVVM”选项卡时运行查询

C# 仅当选择了“WPF MVVM”选项卡时运行查询,c#,wpf,xaml,mvvm,datagrid,C#,Wpf,Xaml,Mvvm,Datagrid,我正在寻找一种方法,就是检查我的ViewModel是否选中了某个选项卡并运行一些查询。以下是我的设想: 我有两个选项卡-选项卡1包含一个带有一些代码隐藏的数据网格,而选项卡2仅包含一些绑定到我的ViewModel的文本框。两个选项卡共享一个数据选择器。当我从Tab1中的datagrid中选择一行时,日期会发生变化,这会触发绑定到Tab2中文本框的一系列查询,因为所有查询都使用所选月份作为参数 这使得它变得非常无效,并且datagrid行选择变得非常慢。我怎样才能避免这种情况?设置我的ViewMo

我正在寻找一种方法,就是检查我的ViewModel是否选中了某个选项卡并运行一些查询。以下是我的设想:

我有两个选项卡-选项卡1包含一个带有一些代码隐藏的数据网格,而选项卡2仅包含一些绑定到我的ViewModel的文本框。两个选项卡共享一个数据选择器。当我从Tab1中的datagrid中选择一行时,日期会发生变化,这会触发绑定到Tab2中文本框的一系列查询,因为所有查询都使用所选月份作为参数

这使得它变得非常无效,并且datagrid行选择变得非常慢。我怎样才能避免这种情况?设置我的ViewModel以检查是否选择了Tab2,然后才运行查询的简单方法是什么?我想在TabControl中绑定selectedIndex,但无法使其工作。我对这方面还不太熟悉,非常感谢您的帮助

视图模型

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Location.Model;
using System.Windows.Controls;

namespace Location.ViewModel
{
    public class LocationViewModel: INotifyPropertyChanged
    {
        public LocationViewModel()
        {
            SetEfficiency();
        }

        private DateTime _mDate = DateTime.Now;

        public DateTime MDate
        {
            get { return _mDate; }
            set 
            {
                _mDate = value;
                OnPropertyChanged("MDate");
                SetEfficiency();
            }
        }

        decimal efficiency;

        public decimal Efficiency
        {
            get { return efficiency; }
            set
            {
                efficiency = value;
                OnPropertyChanged("Efficiency");
            }
        }

        DailyEntities db = new DailyEntities();

        private void SetEfficiency()
        {
            var month;
            int.TryParse(MDate.ToString("MM"), out month);
            Efficiency = Convert.ToDecimal(db.LocationKPI.Where(a => a.sMonth == month).Select(a => a.Efficiency).FirstOrDefault());
        }

        public event PropertyChangedEventHandler PropertyChanged;

        protected virtual void OnPropertyChanged(string propertyName = null)
        {
            if (PropertyChanged != null) PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
        }
    }
}
MainWindow.xaml.cs

    public MainWindow()
    {
        InitializeComponent();

        DataContext = new LocationViewModel();

        string connectionString = "datasource=xx.xx.xxx.xxx;port=xxx;username=xxxxx;password=xxxxx";
        string sMonth = DateTime.Now.ToString("MM");
        string sYear = DateTime.Now.ToString("yyyy");

        MySqlConnection connection = new MySqlConnection(connectionString);

        MySqlCommand cmd = new MySqlCommand("Select * from MyTable where MONTH(Date) = @sMonth AND YEAR(Date) = @sYear", connection);

        try
        {
            connection.Open();
            cmd.Parameters.Add(new MySqlParameter("sMonth", sMonth));
            cmd.Parameters.Add(new MySqlParameter("sYear", sYear));

            DataTable dt = new DataTable();
            dt.Load(cmd.ExecuteReader());
            dtGrid.DataContext = dt;
            connection.Close();

        }

        catch (Exception ex)
        {
            MessageBox.Show(ex.Message);
        }



    }

    private void vDatePick_SelectedDateChanged(object sender, SelectionChangedEventArgs e)
    {

            string connectionString = "datasource=xx.xx.xxx.xxx;port=xxx;username=xxxxx;password=xxxxx";
            string sMonth = DateTime.Parse(vDatePick.Text).ToString("MM");
            string sYear = DateTime.Parse(vDatePick.Text).ToString("yyyy");
            string vDate = DateTime.Parse(vDatePick.Text).ToString("yyyy-MM-dd");

            MySqlConnection connection = new MySqlConnection(connectionString);
            MySqlCommand cmd = new MySqlCommand("Select * from MyTable where MONTH(Date) = @sMonth AND YEAR(Date) = @sYear", connection);


            try
            {

                connection.Open();
                cmd.Parameters.Add(new MySqlParameter("sMonth", sMonth));
                cmd.Parameters.Add(new MySqlParameter("sYear", sYear));
                DataTable dt = new DataTable();
                dt.Load(cmd.ExecuteReader());
                connection.Close();
                dtGrid.DataContext = dt;

            }

            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }

    }


    private void dtGrid_SelectedCellsChanged(object sender, SelectedCellsChangedEventArgs e)
    {

        DataRowView row_selected = dtGrid.SelectedItem as DataRowView;
        if (row_selected == null) return;
        vDatePick.Text = row_selected["Date"].ToString();
        txtHours.Text = row_selected["Hours"].ToString();

    }
谢谢

  • 添加选项卡Control this
    SelectedIndex=“{Binding SelectedTabIndex,Mode=TwoWay}
  • 更改您的方法,如下所示:

    private void vDatePick_SelectedDateChanged(object sender, SelectionChangedEventArgs e) 
    {
        if(SelectedTabIndex == 1)
        {
        //... your code 
       }
    }
    
      • 添加选项卡Control this
        SelectedIndex=“{Binding SelectedTabIndex,Mode=TwoWay}
      • 更改您的方法,如下所示:

        private void vDatePick_SelectedDateChanged(object sender, SelectionChangedEventArgs e) 
        {
            if(SelectedTabIndex == 1)
            {
            //... your code 
           }
        }
        

      你好,卡兰巴。我尝试了你的方法,但我得到了以下错误:“该名称在当前上下文中不存在。”我的ViewModel中是否应该有if语句?Hello@iCosmin。.xaml和.cs类应该具有相同的命名空间。因为他们是偏袒的
      并且您必须将
      公共int-SelectedTabIndex{get;set;}
      属性添加到MainWİndow类中。您好,Karamba。我尝试了你的方法,但我得到了以下错误:“该名称在当前上下文中不存在。”我的ViewModel中是否应该有if语句?Hello@iCosmin。.xaml和.cs类应该具有相同的命名空间。因为他们是偏袒的
      并且必须将
      公共int-SelectedTabIndex{get;set;}
      属性添加到MainWİndow类中。