【问题标题】:how to load data into combobox from datagridview如何从datagridview将数据加载到组合框中
【发布时间】:2017-04-07 13:20:58
【问题描述】:

我想将数据从datagridview加载到另一个表单中的组合框以更新问题是在productname组合框中没有针对productid选择特定项目什么是解决方案请帮助

// Code of gridview form 

     private void invoiceItemsDetailsDataGridView_DoubleClick(object sender, EventArgs e)
    {
        int index = invoiceItemsDetailsDataGridView.Rows.GetFirstRow(DataGridViewElementStates.Selected);
        //string productid = invoiceItemsDetailsDataGridView.Rows[index].Cells["ProductId"].Value.ToString();
        //string productName = invoiceItemsDetailsDataGridView.Rows[index].Cells["ProductName"].Value.ToString();

        invoiceItemDetailChangeForm icf = new invoiceItemDetailChangeForm();
        icf.CurrentQuantity = Convert.ToUInt16(invoiceItemsDetailsDataGridView.Rows[index].Cells["Quantity"].Value);
        icf.ProductId = Convert.ToUInt16(invoiceItemsDetailsDataGridView.Rows[index].Cells["ProductID"].Value); ;
        icf.ShowDialog();
    }

//invoiceItemDetailChangeForm 中声明的类级别 int 进行更新

    public int CurrentQuantity { get; set; }

    public int ProductId { get; set; }

// invoiceItemDetailChangeForm表单中combobox相关代码

    private void invoiceItemDetailChangeForm_Load(object sender, EventArgs e)
    {
        QtyTextBox.Text = CurrentQuantity.ToString();
        ProductNameComboBox.SelectedValue = ProductId;

        ProductNameComboBox.DisplayMember = "ProductName";
        ProductNameComboBox.ValueMember = "ProductID";
        ProductNameComboBox.DataSource = GetAllProducts();
        //ProductNameComboBox.SelectedValue = -1;

    }

    private object GetAllProducts()
    {
        DataTable dtProducts = new DataTable();
        string connString = ConfigurationManager.ConnectionStrings["dbZ"].ConnectionString;
        using (SqlConnection conn = new SqlConnection(connString))
        {
            using (SqlCommand cmd = new SqlCommand("usp_GetAllProductsForPOS", conn))
            {
                cmd.CommandType = CommandType.Text;
                conn.Open();

                SqlDataReader reader = cmd.ExecuteReader();
                dtProducts.Load(reader);
            }
        }
        return dtProducts;
    }

【问题讨论】:

    标签: c# winforms datagridview combobox


    【解决方案1】:

    您在绑定之前设置选定的值,您必须在绑定之后移动它

    试试这个

    private void invoiceItemDetailChangeForm_Load(object sender, EventArgs e)
        {
            QtyTextBox.Text = CurrentQuantity.ToString();
    
    
            ProductNameComboBox.DisplayMember = "ProductName";
            ProductNameComboBox.ValueMember = "ProductID";
            ProductNameComboBox.DataSource = GetAllProducts();
            //ProductNameComboBox.SelectedValue = -1;
            ProductNameComboBox.SelectedValue = ProductId;
    
        }
    

    【讨论】:

      猜你喜欢
      • 2016-10-29
      • 1970-01-01
      • 2017-08-12
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2016-02-04
      • 1970-01-01
      • 2014-09-11
      相关资源
      最近更新 更多