DataGrid提供了一些内在支持,有一个整型属性,EditItemIndex,表示哪一行可以编辑,一但设置,
该行的文本输入框显示,而不是却省的静态文本,如为-1则表示没有行可以编辑。
DataGrid可以包含一个控件,EditCommandColumn,它将为DataGrid引发三个事件,EditCommand,
UpdateCommand,和CancelCommand。EditCommandColumn在属性中用Columns定义,如:
<ASP:DataGrid id="MyDataGrid" runat="server"
......
onEditCommand="MyDataGrid_Edit"
onCancelCommand="MyDataGrid_Cancel"
onUpdateCommand="MyDataGrid_Update"
DataKeyField="au_id"
>
<property name="Columns">
<asp:EditCommandColumns EditText="编辑" CancelText="取消" UpdateText="更新"/>
</property>
</ASP:DataGrid>
Edit事件中参数DataGridCommandEventArgs参数包含了用户选择的行,然后我们可以重新帮定,
以刷新显示。例:
public void MyDataGrid_Edit(Object sender,DataGridCommandEventArgs E){
MyDataGrid.EditItemIndex = (int)E.Item.ItemIndex;
BindGrid();//调用另外的函数实现重新帮定
}
在Cancel事件中,我们只需要把EditItemIndex设为-1就可以了。
在Update事件中,我们需要更新数据。要知道当前行的主键值,这可以用刚才设的DataKeyField
来获得,我们可以获得行的主键值,如:
myCommand.Parameters["@id"].Value=MyDataGrid.DataKeys[(int)E.Item.ItemIndex];
最后将EditItemIndex设为-1。
为了防止用户修改主键,可以单独定义一行中各列的表现,将其改为只读,如:
<ASP:DataGrid id="MyDataGrid" runat="server"
......
DataKeyField="au_id"
AutoGenerateColumns="false"
>
<property name="Columns">
<asp:EditCommandColumn EditText="编辑" CancleText="取消" UpdateText="更新"/>
<asp:BoundColumn HeaderText="au_id" SortField="au_id" ReadOnly="True" DataField="au_id"/>
<asp:BoundColumn HeaderText="电话" Sor
该行的文本输入框显示,而不是却省的静态文本,如为-1则表示没有行可以编辑。
DataGrid可以包含一个控件,EditCommandColumn,它将为DataGrid引发三个事件,EditCommand,
UpdateCommand,和CancelCommand。EditCommandColumn在属性中用Columns定义,如:
<ASP:DataGrid id="MyDataGrid" runat="server"
......
onEditCommand="MyDataGrid_Edit"
onCancelCommand="MyDataGrid_Cancel"
onUpdateCommand="MyDataGrid_Update"
DataKeyField="au_id"
>
<property name="Columns">
<asp:EditCommandColumns EditText="编辑" CancelText="取消" UpdateText="更新"/>
</property>
</ASP:DataGrid>
Edit事件中参数DataGridCommandEventArgs参数包含了用户选择的行,然后我们可以重新帮定,
以刷新显示。例:
public void MyDataGrid_Edit(Object sender,DataGridCommandEventArgs E){
MyDataGrid.EditItemIndex = (int)E.Item.ItemIndex;
BindGrid();//调用另外的函数实现重新帮定
}
在Cancel事件中,我们只需要把EditItemIndex设为-1就可以了。
在Update事件中,我们需要更新数据。要知道当前行的主键值,这可以用刚才设的DataKeyField
来获得,我们可以获得行的主键值,如:
myCommand.Parameters["@id"].Value=MyDataGrid.DataKeys[(int)E.Item.ItemIndex];
最后将EditItemIndex设为-1。
为了防止用户修改主键,可以单独定义一行中各列的表现,将其改为只读,如:
<ASP:DataGrid id="MyDataGrid" runat="server"
......
DataKeyField="au_id"
AutoGenerateColumns="false"
>
<property name="Columns">
<asp:EditCommandColumn EditText="编辑" CancleText="取消" UpdateText="更新"/>
<asp:BoundColumn HeaderText="au_id" SortField="au_id" ReadOnly="True" DataField="au_id"/>
<asp:BoundColumn HeaderText="电话" Sor
| 对此文章发表了评论 |
