gridview中的文本框不会自动回发

时间:2014-01-26 12:19:14

标签: c# asp.net gridview textbox

我的gridview在发回时错过了以前的数据。这是一个场景,当我从gvFinalised gridview检测到库存不足时,我得到了类别,然后我得到了库存最高的产品并显示在gvSuggested gridview中。

但是,在我的gvFinalised中,有三种不同类别的产品是不够的,假设它们是面条,罐头食品和饮料。它应该显示三种不同的产品,每种产品的最高库存来自gvSuggested中的不同类别。

然而,我现在的问题是,它只显示最后的项目。例如,在此业务情景中,饮料。饮料之前的数据刚刚消失。

以下是我如何检测库存不足的代码:

protected void tbQuantity_TextChanged(object sender, EventArgs e)
{
    tempList = new Dictionary<string, string>();
    distSPUItemList = new Dictionary<string, int>();
    bool valid = true;
    string quantityStr = "", prodID = "";
    int packagesNeeded = 0, totalUnit = 0, quantity = 0;

    //Get the total packages needed for this distribution
    packagesNeeded = prodPackBLL.getPackagesNeededByDistributionID(distributionID);

    foreach (GridViewRow gr in gvFinalised.Rows)
    {
        //Clear label error message
        Label lblCheckAmount = gr.FindControl("lblCheckAmount") as Label;
        lblCheckAmount.Text = "";

        //Get the product variant ID which set as DataKeyNames and product quantity from selected row index
        prodID = gvFinalised.DataKeys[gr.RowIndex].Value.ToString();

        var tbQuantity = gr.FindControl("tbQuantity") as TextBox;
        if (tbQuantity != null)
        {
            //Check if the input is numeric
            quantityStr = tbQuantity.Text;
            if (!int.TryParse(quantityStr, out quantity))
            {
                lblCheckAmount.Text = "Non-numeric input!";
                TextBox tb = (TextBox)gr.FindControl("tbQuantity") as TextBox;
            }
            else
            {
                //Add both objects into Dictionary
                tempList.Add(prodID, quantityStr);
            }
        }
    }

    //Portion to check the storage level for each products stored in tempList
    //Loop thru tempList. key as prod variant ID, tempList.Keys as quantity
    foreach (string key in tempList.Keys)
    {
        //Get total unit of each products
        totalUnit = prodPackBLL.getTotalProductUnit(key);
        valid = true;

        //Check if unitQuantity exceed storage level
        if (((Convert.ToInt32(tempList[key])) * packagesNeeded) > totalUnit)
        {
            //Get the label control in gridview
            foreach (GridViewRow gr in gvFinalised.Rows)
            {
                if (key == gvFinalised.DataKeys[gr.RowIndex].Value.ToString())
                {
                    //Change the color of textBox and display the insufficient message
                    valid = false;
                    //Automatically uncheck the checkBox if invalid
                    TextBox tb = (TextBox)gr.FindControl("tbQuantity") as TextBox;
                    Label lblCheckAmount = gr.FindControl("lblCheckAmount") as Label;
                    lblCheckAmount.Text = "Insufficient stock!";

                    //Here is the place where I collect the data and display in gvSuggested
                    getSuggested(key);
                }
            }
        }
        else
        {
            if (totalUnit - ((Convert.ToInt32(tempList[key])) * packagesNeeded) == 0)
            {

                foreach (GridViewRow gr in gvFinalised.Rows)
                {
                    if (key == gvFinalised.DataKeys[gr.RowIndex].Value.ToString())
                    {
                        valid = true;
                        Label lblCheckAmount = gr.FindControl("lblCheckAmount") as Label;
                        lblCheckAmount.Attributes["style"] = "color:#ffb848";
                        lblCheckAmount.Text = "Stock becomes 0!";
                    }
                }
            }
        }

        //Portion to check for valid products to be inserted into distSPUItemList
        if (valid)
        {
            //Set the textBox color
            foreach (GridViewRow gr in gvFinalised.Rows)
            {
                if (key == gvFinalised.DataKeys[gr.RowIndex].Value.ToString())
                {
                    TextBox tb = (TextBox)gr.FindControl("tbQuantity") as TextBox;
                }
            }
            //Validated items store into another list to perform Sql statement when button on click
            distSPUItemList.Add(key, (Convert.ToInt32(tempList[key]) * packagesNeeded));
        }
    }
}

以下是填充getSuggested()的{​​{1}}方法:

gvSuggeted

我在回发时使用了protected void getSuggested(string prodVariantID) { string categoryName = prodPackBLL.getCategoryByProdVariantID(prodVariantID); //Get the list of substitute product with highest storage level sorted in descending order List<ProductPacking> prodSubstitute = new List<ProductPacking>(); List<string> lstCategory = new List<string>(); List<string> prodIDList = new List<string>(); List<DistributionStandardPackingUnitItems> distSPUItem = new List<DistributionStandardPackingUnitItems>(); distSPUItem = this.SuggestedItems; //Find list of substitute with highest stock level and replace the product prodSubstitute = prodPackBLL.getProductIDWithHighestStock(categoryName); for (int count = 0; count < prodSubstitute.Count; count++) { //To prevent duplication of same product and select those catories which are in current category and counting them and taking them if there are less than 1 occurrences if (!prodIDList.Contains(prodSubstitute[count].id) && !(lstCategory.Where(x => x.Equals(categoryName)).Select(x => x).Count() >= 2)) { prodIDList.Add(prodSubstitute[count].id); lstCategory.Add(categoryName); } } for (int j = 0; j < prodIDList.Count; j++) { //Get the detail of the product added into prodList and add it into distSPUItem List distSPUItem.Add(packBLL.getSPUItemDetailByID(prodIDList[j])); } gvSuggested.DataSource = distSPUItem; gvSuggested.DataBind(); this.SuggestedItems = distSPUItem; } private List<DistributionStandardPackingUnitItems> SuggestedItems { get { if (ViewState["SuggestedItems"] == null) { return new List<DistributionStandardPackingUnitItems>(); } else { return (List<DistributionStandardPackingUnitItems>)ViewState["SuggestedItems"]; } } set { ViewState["SuggestedItems"] = value; } } 来存储数据。但是,它不起作用。 gvSuggested

中的这一行
viewState

导致我在gridView中的文本框不自动回发。如果我删除它,上面的错误再次出现。任何指南?提前谢谢。

1 个答案:

答案 0 :(得分:0)

请启用tbQuantity文本框EnableAutoPostBack = True