2012-01-26 3 views
0

한 gridview 중 다른 내에서 중첩하려고하지만 두 번째 눈금보기에서 데이터를 채울 수 없습니다. 두 번째 데이터 표의 데이터 소스를 설정하려고 할 때 오류가 발생합니다 (null이라고 말함). 누구든지 도와 줄 수 있습니까? 여기 는 영문 페이지입니다 :중첩 GridView 문제

<div id="divSource" runat="server" align="center"> 
<asp:GridView ID="Source" runat="server" AutoGenerateColumns="False" DataKeyNames="sourceLineItem" CSSClass="viewSourceGrid" OnRowDataBound="PopulateDateCodes"> 
    <Columns> 
     <asp:TemplateField InsertVisible="False" HeaderStyle-Width="70px"> 
      <ItemTemplate> 
       <asp:Label CssClass="sourceHeader" runat="server" Text= '<%# "Source: " + (Container.DataItemIndex + 1).ToString() %>'> </asp:Label> 
      </ItemTemplate> 
     </asp:TemplateField> 
     <asp:BoundField DataField="nfdBroker" HeaderText="NFD/Broker" InsertVisible="False" ReadOnly="True" SortExpression="nfdBroker" /> 
     <asp:BoundField DataField="locationDescription" HeaderText="Material Location" SortExpression="materialLocation" /> 
     <asp:BoundField DataField="origPkg" HeaderText="Original Packaging?" SortExpression="origPkg" /> 
     <asp:BoundField DataField="oemCC" HeaderText="OEM C of C? " InsertVisible="False" ReadOnly="True" SortExpression="oemCC" /> 
     <asp:BoundField DataField="minBuyQty" HeaderText="Minimum Buy Qty" SortExpression="minBuyQty" /> 
     <asp:BoundField DataField="deliveryInfo" HeaderText="Delivery" SortExpression="delUOM" /> 

     <asp:TemplateField InsertVisible="False" HeaderText="Date Codes" > 
      <ItemTemplate>    
       <asp:GridView ID="DateCodeGrid" runat="server" InsertVisible="False" DataKeyNames="dateCode" CSSClass="viewSourceGrid" > 
        <Columns> 
         <asp:BoundField DataField="dateCode" SortExpression="dateCode"> 
          <ItemStyle Width="20%" /> 
         </asp:BoundField> 
        </Columns> 
       </asp:GridView> 
      </ItemTemplate> 
     </asp:TemplateField> 

    </Columns> 
</asp:GridView> 

다음 여기에 뒤에 코드 :

public partial class Controls_ViewSource : System.Web.UI.UserControl 
{ 
    //Set the Source Line Item 
    public int SourceLineItem { get; set; } 

    protected void Page_Load(object sender, EventArgs e) 
    { 
     this.SourceLineItem = SourceLineItem; 
     RequestDB db = new RequestDB(); 
     DataSet sources = db.GetSource(int.Parse(Request.QueryString["requestNumber"]), SourceLineItem); 
     Source.DataSource = sources; 
     Source.DataBind(); 

    } 

    protected void PopulateDateCodes(object sender, GridViewRowEventArgs e) 
    { 
     RequestDB db = new RequestDB(); 
     int index = e.Row.RowIndex; 
     GridView gv = (GridView)Source.Rows[0].FindControl("DateCodeGrid"); 
     //int sourceLineItem = int.Parse(Source.DataKeyNames[0].ToString()); 
     //Response.Write(Source.DataKeyNames[0].ToString()); 
     DataSet dateCodes = db.GetDateCodes(71); 
     gv.DataSource = dateCodes; 
     gv.DataBind(); 

    } 
} 
+0

'db.GetDateCodes'에 대한 코드도 표시 할 수 있습니까? 네가 중첩 된 데이터에 연결되어 있지 않은 것 같아. –

+0

또한 GV 인구 코드가 이상합니다. gridview를 채우지 않고 첫 번째 행 안의 첫 번째 중첩 된 gridview 만있는 것처럼 보입니까? 외부 그리드 뷰가 먼저 데이터 바인딩되어야합니다. –

답변

3

당신은 데이터 바인딩되고있는 행의 중첩 격자를 찾을 필요가있을 것이다는 :

GridViewRow row = e.Row; 

데이터 행에만이 작업을 수행해야합니다. 머리말 또는 꼬리말 행 :

if(row.RowType == DataControlRowType.DataRow) 
{ 
    // Find the nested grid view 
    GridView nested = (GridView)row.FindControl("DateCodeGrid"); 

    // The rest of your code for binding the nested grid view follows here 
} 
+0

굉장하다. 감사! – shawleigh17