asp.net中GridView全选后进行批量删除
2012-09-05 17:23
323 查看
<form id="form1" runat="server">
<asp:Button ID="Delall" runat="server" Text="删除选中" onclick="Delall_Click" />
<div>
<asp:GridView ID="gvUser" runat="server"
AutoGenerateColumns="False" DataKeyNames="UserId"
DataSourceID="ObjectDataSourceUser" onrowdeleted="gvUser_RowDeleted"
CellPadding="4" ForeColor="#333333" GridLines="None" AllowPaging="True"
PageSize="3">
<AlternatingRowStyle BackColor="White" ForeColor="#284775" />
<Columns>
<asp:TemplateField>
<HeaderTemplate>
<input id="CheckAll" type="checkbox" onclick="selectAll(this);" />全选
</HeaderTemplate>
<ItemTemplate>
<asp:CheckBox runat="server" ID="CheckSingle" />
</ItemTemplate>
<ItemStyle Width="100px" />
</asp:TemplateField>
<asp:BoundField DataField="UserId" HeaderText="UserId"
SortExpression="UserId" />
<asp:BoundField DataField="UserName" HeaderText="UserName"
SortExpression="UserName" />
<asp:BoundField DataField="UserPass" HeaderText="UserPass"
SortExpression="UserPass" />
<asp:BoundField DataField="Role" HeaderText="Role" SortExpression="Role" />
<asp:BoundField DataField="RegTime" HeaderText="RegTime"
SortExpression="RegTime" />
<asp:BoundField DataField="LogNum" HeaderText="LogNum"
SortExpression="LogNum" />
<%--<asp:CommandField ShowEditButton="True" />--%>
<asp:TemplateField>
<EditItemTemplate>
<asp:LinkButton ID="LinkButton4" runat="server" CommandName="update">更新</asp:LinkButton>
<asp:LinkButton ID="LinkButton5" runat="server" CommandName="cancel">取消</asp:LinkButton>
</EditItemTemplate>
<ItemTemplate>
<asp:LinkButton ID="LinkButton3" runat="server" CommandName="Edit">编辑</asp:LinkButton>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="操作" ShowHeader="False">
<ItemTemplate>
<asp:LinkButton ID="lbDelete" runat="server" CausesValidation="False"
OnClientClick="return confirm('你确定要删除吗?')" Text="删除" CommandName="Delete" ></asp:LinkButton>
</ItemTemplate>
<HeaderStyle ForeColor="#0033CC" />
<ItemStyle HorizontalAlign="Center" VerticalAlign="Middle" />
</asp:TemplateField>
</Columns>
<EditRowStyle BackColor="#999999" />
<FooterStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" />
<HeaderStyle BackColor="Black" Font-Bold="True" ForeColor="White" />
<PagerStyle BackColor="#284775" ForeColor="White" HorizontalAlign="Center" />
<RowStyle BackColor="#F7F6F3" ForeColor="#333333" />
<SelectedRowStyle BackColor="#E2DED6" Font-Bold="True" ForeColor="#333333" />
<SortedAscendingCellStyle BackColor="#E9E7E2" />
<SortedAscendingHeaderStyle BackColor="#506C8C" />
<SortedDescendingCellStyle BackColor="#FFFDF8" />
<SortedDescendingHeaderStyle BackColor="#6F8DAE" />
</asp:GridView>
<asp:ObjectDataSource ID="ObjectDataSourceUser" runat="server"
DataObjectTypeName="User" DeleteMethod="DeleteUser" InsertMethod="AddUser"
SelectMethod="GetAllUsers" TypeName="UserService" UpdateMethod="ModifyUser">
</asp:ObjectDataSource>
</div>
</form>
<script type="text/javascript">
function selectAll(obj) {
var chkall = obj;
State = chkall.checked;
elem = chkall.form.elements;
for (i = 0; i < elem.length; i++) {
if (elem[i].type == "checkbox" && elem[i] != chkall.id) {
if (elem[i].checked != State) {
elem[i].click();
}
}
}
}
</script>
protected void Delall_Click(object sender, EventArgs e)
{
int intCount = this.gvUser.Rows.Count;
for (int i = 0; i < intCount; i++)
{
CheckBox CheckSingle = this.gvUser.Rows[i].Cells[0].FindControl("CheckSingle") as CheckBox;
if (CheckSingle.Checked)
{
UserService.DeleteUserByUserId(Convert.ToInt16(this.gvUser.DataKeys[i].Values[0]));
}
}
//删除后的更新
gvUser.DataBind();
}
<asp:Button ID="Delall" runat="server" Text="删除选中" onclick="Delall_Click" />
<div>
<asp:GridView ID="gvUser" runat="server"
AutoGenerateColumns="False" DataKeyNames="UserId"
DataSourceID="ObjectDataSourceUser" onrowdeleted="gvUser_RowDeleted"
CellPadding="4" ForeColor="#333333" GridLines="None" AllowPaging="True"
PageSize="3">
<AlternatingRowStyle BackColor="White" ForeColor="#284775" />
<Columns>
<asp:TemplateField>
<HeaderTemplate>
<input id="CheckAll" type="checkbox" onclick="selectAll(this);" />全选
</HeaderTemplate>
<ItemTemplate>
<asp:CheckBox runat="server" ID="CheckSingle" />
</ItemTemplate>
<ItemStyle Width="100px" />
</asp:TemplateField>
<asp:BoundField DataField="UserId" HeaderText="UserId"
SortExpression="UserId" />
<asp:BoundField DataField="UserName" HeaderText="UserName"
SortExpression="UserName" />
<asp:BoundField DataField="UserPass" HeaderText="UserPass"
SortExpression="UserPass" />
<asp:BoundField DataField="Role" HeaderText="Role" SortExpression="Role" />
<asp:BoundField DataField="RegTime" HeaderText="RegTime"
SortExpression="RegTime" />
<asp:BoundField DataField="LogNum" HeaderText="LogNum"
SortExpression="LogNum" />
<%--<asp:CommandField ShowEditButton="True" />--%>
<asp:TemplateField>
<EditItemTemplate>
<asp:LinkButton ID="LinkButton4" runat="server" CommandName="update">更新</asp:LinkButton>
<asp:LinkButton ID="LinkButton5" runat="server" CommandName="cancel">取消</asp:LinkButton>
</EditItemTemplate>
<ItemTemplate>
<asp:LinkButton ID="LinkButton3" runat="server" CommandName="Edit">编辑</asp:LinkButton>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField HeaderText="操作" ShowHeader="False">
<ItemTemplate>
<asp:LinkButton ID="lbDelete" runat="server" CausesValidation="False"
OnClientClick="return confirm('你确定要删除吗?')" Text="删除" CommandName="Delete" ></asp:LinkButton>
</ItemTemplate>
<HeaderStyle ForeColor="#0033CC" />
<ItemStyle HorizontalAlign="Center" VerticalAlign="Middle" />
</asp:TemplateField>
</Columns>
<EditRowStyle BackColor="#999999" />
<FooterStyle BackColor="#5D7B9D" Font-Bold="True" ForeColor="White" />
<HeaderStyle BackColor="Black" Font-Bold="True" ForeColor="White" />
<PagerStyle BackColor="#284775" ForeColor="White" HorizontalAlign="Center" />
<RowStyle BackColor="#F7F6F3" ForeColor="#333333" />
<SelectedRowStyle BackColor="#E2DED6" Font-Bold="True" ForeColor="#333333" />
<SortedAscendingCellStyle BackColor="#E9E7E2" />
<SortedAscendingHeaderStyle BackColor="#506C8C" />
<SortedDescendingCellStyle BackColor="#FFFDF8" />
<SortedDescendingHeaderStyle BackColor="#6F8DAE" />
</asp:GridView>
<asp:ObjectDataSource ID="ObjectDataSourceUser" runat="server"
DataObjectTypeName="User" DeleteMethod="DeleteUser" InsertMethod="AddUser"
SelectMethod="GetAllUsers" TypeName="UserService" UpdateMethod="ModifyUser">
</asp:ObjectDataSource>
</div>
</form>
<script type="text/javascript">
function selectAll(obj) {
var chkall = obj;
State = chkall.checked;
elem = chkall.form.elements;
for (i = 0; i < elem.length; i++) {
if (elem[i].type == "checkbox" && elem[i] != chkall.id) {
if (elem[i].checked != State) {
elem[i].click();
}
}
}
}
</script>
protected void Delall_Click(object sender, EventArgs e)
{
int intCount = this.gvUser.Rows.Count;
for (int i = 0; i < intCount; i++)
{
CheckBox CheckSingle = this.gvUser.Rows[i].Cells[0].FindControl("CheckSingle") as CheckBox;
if (CheckSingle.Checked)
{
UserService.DeleteUserByUserId(Convert.ToInt16(this.gvUser.DataKeys[i].Values[0]));
}
}
//删除后的更新
gvUser.DataBind();
}
相关文章推荐
- 批量删除记录时如何实现全选方法总结 (转)http://www.cnblogs.com/chenou/articles/1349646.html[Asp.net Ajax 控件]
- asp.net控件的分页批量全选删除
- asp.net 通过js实现批量删除和全选
- asp.net实现批量删除的全选功能案例
- ASP.NET给DataGrid,Repeater等添加全选批量删除等功能
- asp.net gridview多页时的批量删除
- asp.net下gridview 批量删除的实现方法第1/3页
- 在ASP.NET 2.0中操作数据之六十三:GridView实现批量删除数据
- ASP.NET GridView全选,反选,删除选中项
- asp.net gridview实现全选,反选与删除记录的操作代码
- 在ASP.NET 2.0中操作数据之六十三:GridView实现批量删除数据
- asp.net gridview实现全选,反选与删除记录的操作代码
- asp.net下gridview 批量删除的实现方法
- asp.net下gridview 批量删除的实现方法第1/3页
- asp.net gridview多页时的批量删除
- ASP.NET给DataGrid,Repeater等添加全选批量删除等功能(转)
- yii2使用GridView实现数据全选及批量删除按钮示例
- asp.net GridView手写事件,包括取主键、取值、更新、选择、删除
- 关于C#和ASP.NET中对App.config和Web.config文件里的[appSettings]和[connectionStrings]节点进行新增、修改、删除和读取相关的操作
- ASP.NET中GridView控件删除数据的两种方法