2016-08-04 3 views
0

データベースからの製品リストを表示するのにListviewを使用しています。 OnPageのロード製品が正しく読み込まれますが、データページのページ番号を使用してページを切り替えると、このエラーが発生します。Listview Datapager - インデックスが範囲外でした。負でなく、コレクションのサイズより小さくなければならない

インデックスが範囲外です。負でなく、コレクションのサイズより小さくなければなりません。パラメータ名:

事があればあるshop.products_ItemDataBound(オブジェクト送信者、ListViewItemEventArgs e)にSystem.Web.UI.WebControls.DataKeyArray.get_Item(のInt32インデックス)でSystem.Collections.ArrayList.get_Item(のInt32インデックス)のインデックスItemDataBoundを使用すると、このエラーが発生します。それ以外のページは正常に動作します。

<asp:ListView ID="products" runat="server" DataKeyNames="ID" OnPagePropertiesChanging="OnPagePropertiesChanging"> 
          <ItemTemplate> 
           content 
          </ItemTemplate> 

          <LayoutTemplate> 
           <div id="itemPlaceholderContainer" runat="server" style=""> 
            <div runat="server" id="itemPlaceholder" /> 
           </div> 

           <div class="datapager"> 
            <asp:DataPager ID="DataPager1" ClientIDMode="Static" runat="server" PageSize="12" PagedControlID="products" ViewStateMode="Enabled"> 
             <Fields> 
              <asp:NextPreviousPagerField ButtonType="Link" ShowFirstPageButton="false" ShowPreviousPageButton="False" ShowNextPageButton="false" ButtonCssClass="nextPre" /> 
              <asp:NumericPagerField ButtonType="Link" ButtonCount="10" /> 

              <asp:NextPreviousPagerField ButtonType="Link" ShowNextPageButton="true" ShowLastPageButton="false" ShowPreviousPageButton="false" ButtonCssClass="nextPre" /> 
             </Fields> 
            </asp:DataPager> 
            <div class="clear"></div> 
           </div> 
          </LayoutTemplate> 

          <EmptyDataTemplate> 
           <strong>No Items Found....</strong> 
          </EmptyDataTemplate> 
         </asp:ListView> 

項目データバインド

private void products_ItemDataBound(object sender, ListViewItemEventArgs e) 
    { 
     try { 
      if (e.Item.ItemType == ListViewItemType.DataItem) { 
       ListViewDataItem itm = (ListViewDataItem)e.Item; 
       string productID = products.DataKeys(itm.DataItemIndex)("ID"); 
       query = "SELECT stock_status FROM products WHERE ID = '" + productID + "'"; 
       DataTable dt = this.GetData(query); 
       if (dt.Rows.Count > 0) { 
        ((Label)e.Item.FindControl("checkReadyStock")).Text = dt.Rows(0)("stock_status").ToString; 

        if (((Label)e.Item.FindControl("checkReadyStock")).Text == "Ready Stock") { 
         ((Image)e.Item.FindControl("readyStock")).Visible = true; 
        } 
       } 
      } 
     } catch (Exception ex) { 
      Response.Write(ex); 
     } 
    } 

DataPager

protected void OnPagePropertiesChanging(object sender, PagePropertiesChangingEventArgs e) 
{ 
    (products.FindControl("DataPager1") as DataPager).SetPageProperties(e.StartRowIndex, e.MaximumRows, false); 
    products.DataSource = ViewState("Data"); 
    products.DataBind(); 
} 
+0

products_ItemDataBoundに複数のエラーがあります。最初に修正する必要があります。 – VDWWD

+0

@VDWWDどのようなエラーがありますか? – SUN

+0

products_ItemDataBoundからVS 2015にコードをコピーすると、5つのエラーが発生します。 – VDWWD

答えて

0

は、あなたはこれを試みることができます。 'ColumnNameWithID'を正しい名前に変更するだけです。

protected void products_ItemDataBound1(object sender, ListViewItemEventArgs e) 
{ 
    try 
    { 
     if (e.Item.ItemType == ListViewItemType.DataItem) 
     { 
      string productID = DataBinder.Eval(e.Item.DataItem, "ColumnNameWithID").ToString(); 
      string query = "SELECT stock_status FROM products WHERE ID = '" + productID + "'"; 
      DataTable dt = this.GetData(query); 
      if (dt.Rows.Count > 0) 
      { 
       ((Label)e.Item.FindControl("checkReadyStock")).Text = dt.Rows[0][2].ToString(); 
       if (((Label)e.Item.FindControl("checkReadyStock")).Text == "Ready Stock") 
       { 
        ((Image)e.Item.FindControl("readyStock")).Visible = true; 
       } 
      } 
     } 
    } 
    catch (Exception ex) 
    { 
     Response.Write(ex); 
    } 
} 
+0

プライマリキーの列の名前を入力する必要がある場合は、IDはすでに行った列の名前です。 – SUN

+0

はい、そうです。この例では、わかりやすい列名を使用しました。 – VDWWD

関連する問題

 関連する問題