【问题标题】:GridView Error: Object reference not set to an instance of an objectGridView 错误:对象引用未设置为对象的实例
【发布时间】:2012-06-07 12:40:37
【问题描述】:

有一个带有模板字段的网格视图,一列包含一个下拉列表,应该用 sql 语句填充。我已经动态创建了网格并调用了 rowdatabound 以访问下拉列表,但我不断收到错误:对象引用未设置为对象的实例。有人有什么想法吗?

<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False">
    <Columns>
        <asp:CommandField EditText="Add" ShowEditButton="True" />
        <asp:TemplateField>
            <EditItemTemplate>
                <asp:TextBox ID="TextBox1" runat="server" />                          
            </EditItemTemplate>
            <ItemTemplate>
                <asp:Label ID="Label1" runat="server" />
            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField>
            <EditItemTemplate>
                <asp:DropDownList ID="DropDownList1" runat="server" />
            </EditItemTemplate>
            <ItemTemplate>
                <asp:Label ID="Label2" runat="server"></asp:Label>
            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField>
            <EditItemTemplate>
                <asp:TextBox ID="TextBox2" runat="server" />
            </EditItemTemplate>
            <ItemTemplate>
                <asp:Label ID="Label3" runat="server" />
            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField>        
            <EditItemTemplate>
                <asp:DropDownList ID="DropDownList2" runat="server" />        
            </EditItemTemplate>
            <ItemTemplate>
                <asp:Label ID="Label4" runat="server" />
            </ItemTemplate>
            </asp:TemplateField>
        <asp:TemplateField>        
            <EditItemTemplate>
                <asp:TextBox ID="TextBox3" runat="server" />
            </EditItemTemplate>
            <ItemTemplate>
                <asp:Label ID="Label5" runat="server" />        
            </ItemTemplate>
        </asp:TemplateField>
        <asp:TemplateField>
            <EditItemTemplate>
                <asp:Label ID="Label6" runat="server" />
            </EditItemTemplate>
            <ItemTemplate>
                <asp:Label ID="Label7" runat="server" />
            </ItemTemplate>
        </asp:TemplateField>
    </Columns>
</asp:GridView>

这是动态创建 GridView 的代码,这是在 page_load 事件中完成的:

If Not Page.IsPostBack Then
        Dim CommittedTable As New DataTable("Committed")

        CommittedTable.Columns.Add("Date Posted", GetType(Date))
        CommittedTable.Columns.Add("Vendor", GetType(String))
        CommittedTable.Columns.Add("Expense Description", GetType(String))
        CommittedTable.Columns.Add("Ledger", GetType(String))
        CommittedTable.Columns.Add("Amount", GetType(String))
        CommittedTable.Columns.Add("Initials", GetType(String))

        For i As Integer = 0 To GridView1.Rows.Count
            Dim tableRow As DataRow = CommittedTable.NewRow()

            tableRow("Date Posted") = Date.Today
            tableRow("Vendor") = ""
            tableRow("Expense Description") = ""
            tableRow("Ledger") = ""
            tableRow("Amount") = ""
            tableRow("Initials") = ""
            CommittedTable.Rows.Add(tableRow)
        Next

        Session("CommsTable") = CommittedTable
        BindDataComm()

    End If

最后这是 RowDataBound 事件处理程序代码:

Dim ddl As DropDownList = DirectCast(e.Row.FindControl("DropDownList1"), DropDownList)
    If ddl Is Nothing Then
        result = dbConnect(dbType.SqlServer, ConfigurationManager.AppSettings("SQLServerConnection"))
        If result = "Successful" Then
            dt = FillDataTable(dbType.SqlServer, "SELECT V_VendorNo + ' | ' + V_VendorName FROM VendorTbl")
            ddl.DataSource = dt 'it errors out here'
            ddl.DataTextField = "V_VendorNo"
            ddl.DataValueField = "V_VendorName"
            ddl.DataBind()
        End If
    End If

【问题讨论】:

  • If ddl Is Nothing Then,这是打字错误吗? ,看到你的代码这应该是If ddl IsNot Nothing Then
  • 然后当您尝试 Nothing.DataSource = dt 时会出现“对象引用错误”。
  • 我明白了...有关如何修复的任何建议?
  • 不确定,代码似乎正确。尝试将此行放在 FindControl 行 if e.Row.RowType = DataControlRowType.DataRow then 之前,当然还有在 IsNot Nothing 中反转 Is Nothing

标签: asp.net vb.net data-binding gridview drop-down-menu


【解决方案1】:

在绑定 Data in RowDatabound 事件之前是否检查了 Datarow 的 RowType 如果没有请检查...

【讨论】:

  • 是的,我是。我首先检查行类型,然后如果
  • 然后请检查您是否正在填充数据表,即(Datatable.rows.count 应该>0)..这可能会给您带来问题...
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-07-09
  • 2012-08-31
  • 2011-11-21
  • 2012-10-01
  • 1970-01-01
相关资源
最近更新 更多