8

我有一个从 ObjectDataSource 填充的 GridView,它的 DataKeyNames 字段中有两个项目。一个是主键,ID,另一个是类别字段(类别字段用于添加标题行来划分类别)。

显示效果很好,但我正在尝试创建删除操作。对象的删除方法只需要 ID 字段,并且在 ObjectDataSource 中,即使我将该方法定义为只需要一个 ID 字段,.net 也会抱怨,因为它正在寻找一种方法,该方法具有在 DataKeyNames 中定义的两个字段。

如果我将类别的参数添加到 delete 方法,它会起作用,但是定义一个不用于任何东西的参数会很烦人。

我可以将 ObjectDataSource 和 GridView 对象配置为具有 DataKeyNames 的两个值,但具体应该传递给哪些方法?

这两个对象的(简化)定义是:

<asp:ObjectDataSource ID="ObjDS1" runat="server" SelectMethod="getAllItems" 
    TypeName="Items" DeleteMethod="deleteItem">
    <DeleteParameters>
        <asp:Parameter Name="ID" Type="Int32" />
       <!-- This shouldn't be necessary: -->
        <asp:Parameter Name="Category" Type="String" />
    </DeleteParameters>
</asp:ObjectDataSource>

<asp:GridView ID="gvJItems" runat="server" AutoGenerateColumns="False" DataKeyNames="ID,Category" 
    DataSourceID="ObjDS1">
        <Columns>
            <asp:BoundField DataField="ID" Visible="false"  HeaderText="ID" />
            <asp:BoundField DataField="Name" HeaderText="Name" ItemStyle-Width="85%"/>
            <asp:TemplateField>
                <ItemTemplate>
                    <asp:LinkButton ID="lbDelete" Runat="server" 
                        OnClientClick="return confirm('Are you sure you want to delete this?');"
                            CommandName="Delete">Delete</asp:LinkButton>
                </ItemTemplate>
            </asp:TemplateField>
        </Columns>
    </asp:GridView>
4

4 回答 4

10

所有 DataKey 值将始终传递给 Delete 方法,因为由DataKeyNames命名的字段旨在成为唯一标识 GridView 中该项目的一个或多个字段。正如您在这里一样,它们通常用于在 ViewState 中以每行为基础轻松维护额外字段,但这样做会产生您在使用 ObjectDataSource 方法时看到的副作用。

要回答您的原始问题,不,您不能在 DataKeyNames 中将 Category 传递给 Delete 方法。不过,您可以通过将值放在模板列中的隐藏输入中来维护 ViewState 中的值。不过,与忽略 Delete 方法的参数相比,获取该值需要更多的工作。

于 2008-11-28T20:43:00.747 回答
1

我的 gridview 与对象数据源有同样的问题,我是如何处理这种情况的:我在 SQL 端使用 StoredProcs。我在存储过程中又添加了一个参数,虽然我不需要那个参数。它工作得很好

于 2011-11-18T14:37:11.450 回答
1

您可以使用ObjectDataSource更新/删除事件来删除它们

void ODS_Updating(Object sender, ObjectDataSourceMethodEventArgs e)
{
  e.InputParameters.Remove("Type_ID");
  e.InputParameters.Remove("Document_ID");
  e.InputParameters.Remove("State_ID");
}

我将DataKeys用于查找目的,但在更新过程中不需要它们。

于 2012-02-02T17:36:36.913 回答
0

当使用默认的声明式删除方法时,GridView 会将这两个值都传递给 ObjectDataSource。

如果您真的不喜欢额外的参数,另一种方法是取消声明性方法并使用您自己的方法(您可以在那里删除不必要的参数),但这需要更多代码。

于 2008-11-28T17:30:12.383 回答