asp.net多个网格视图 - 不显示数据

时间:2015-02-14 14:46:38

标签: c# asp.net gridview

我有两个GridView,我想要来自两个DataTables的显示数据。在aspx文件中有我的GridViews代码:

 <div class="col-sm-5">
        <div class="col-sm-6">
            <asp:GridView ID="gvSource" runat="server" ShowHeaderWhenEmpty="true" CssClass="drag_drop_grid GridSrc" AutoGenerateColumns="false">
                <Columns>
                    <asp:TemplateField>
                        <HeaderTemplate>Miejsca (wybór)</HeaderTemplate>
                        <ItemTemplate>
                            <asp:Label ID="lblNazwa" runat="server" Text='<%# Eval("Nazwa") %>' />
                            <asp:HiddenField ID="IDVal" ClientIDMode="Static" runat="server" Value='<%# Eval("ID") %>' />
                        </ItemTemplate>
                    </asp:TemplateField>

                </Columns>

            </asp:GridView>
        </div>


        <div class="col-sm-6 pull-left">
            <asp:GridView ID="gvDest" runat="server" ShowHeaderWhenEmpty="true" EmptyDataText="No data to display" CssClass="drag_drop_grid GridDest" AutoGenerateColumns="false">
                <Columns>
                    <asp:TemplateField>
                        <HeaderTemplate>Miejsca (należące do wycieczki)</HeaderTemplate>
                        <ItemTemplate>
                            <asp:Label ID="lblNazwa"  runat="server" Text='<%# Eval("Nazwa") %>' />
                            <asp:HiddenField ID="IDVal" ClientIDMode="Static" runat="server" Value='<%# Eval("Id") %>' />
                        </ItemTemplate>
                    </asp:TemplateField>

                </Columns>

            </asp:GridView>
        </div>
    </div>

我的代码背后:

protected void Page_Load(object sender, EventArgs e)
    {
        if (!Page.IsPostBack)
        {

            if (!string.IsNullOrWhiteSpace(Request.QueryString["id"]))
            {
                recID = int.Parse(Request.QueryString["id"]);
                if (recID > 0)
                {
                    DataTable dt = new DataTable();
                    DataTable dt2 = new DataTable();
                    dt.Columns.AddRange(new DataColumn[2] { new DataColumn("Id", typeof(int)), new DataColumn("Nazwa", typeof(string)) });
                    dt2.Columns.AddRange(new DataColumn[2] { new DataColumn("Id", typeof(int)), new DataColumn("Nazwa", typeof(string)) });

                    Miejsca ms = new Miejsca();
                    Hashtable hs = new Hashtable();


                    foreach (var lst in ms.PobierzMiejscaLista(hs))
                    {

                        dt.Rows.Add(lst.Id , lst.Nazwa);
                    }

                    gvSource.UseAccessibleHeader = true;
                    gvSource.DataSource = dt;

                    gvSource.DataBind();

                   dt.Rows.Clear();
                   dt.Rows.Add();

                    Wycieczka w = (new Wycieczki()).PobierzWycieczke(recID);



                    foreach (var lst in w.Miejsca)
                    {
                        Miejsce tempM = (new Miejsca()).PobierzMiejsce(lst.Id_Miejsce.Id);
                        dt2.Rows.Add(tempM.Id, tempM.Nazwa);

                    }
                    int ilosc = dt2.Rows.Count;
                    //gvDest.UseAccessibleHeader = true;
                    gvDest.DataSource = dt2;
                    gvDest.DataBind();


                    //Page.ClientScript.RegisterClientScriptBlock(typeof(Page), "TablicaMiejsc", "loadPlacesIntoTrip("+recID+");", true);
                }


            }
            else
            {
                DataTable dt = new DataTable();
                dt.Columns.AddRange(new DataColumn[2] { new DataColumn("Id"), new DataColumn("Nazwa") });


                Miejsca ms = new Miejsca();
                Hashtable hs = new Hashtable();

                foreach (var lst in ms.PobierzMiejscaLista(hs))
                {
                    //listMiejsc.Add(lst);
                    dt.Rows.Add(lst.Id, lst.Nazwa);
                }

                gvSource.UseAccessibleHeader = true;
                gvSource.DataSource = dt;

                gvSource.DataBind();

                dt.Rows.Clear();
                dt.Rows.Add();
                gvDest.DataSource = new List<String>();
                gvDest.DataBind();
                recID = 0;
            }

        }
    }

我不知道为什么只有一个GridView(gvSource)显示数据。 第二个GridView(gvDest)不显示数据。 当我调试代码时,我看到两个DataTable都有数据。两个GridView DataSource都有数据。但只有一个GridView显示数据。

我使用Nhibernate来延迟加载(w.Miejsca)集合,并从数据库中获取“Miejsce”或“Wycieczka”等对象。我还使用JQuery和JQuery UI来制作可排序的GridView。

抱歉我的英语不好,这不是我的母语。 我希望你能帮助我:)。

更新

最后我发现了造成这种情况的原因。 因为我的愚蠢,我失去了很多时间:)

从GridView中删除了这行代码:

$("[id*=gvDest] tr:not(tr:first-child)").remove();

感谢您的建议。 问题解决了。

1 个答案:

答案 0 :(得分:0)

请删除ClientIDMode =&#34;静态&#34;从第二个网格视图并检查它。