在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
首现我们拖入一个DataGridView控件到.aspx页面中,然后绑定你需要显示的列,具体代码如下。 复制代码 代码如下: <asp:GridView ID="gvDepartList" runat="server" AutoGenerateColumns="False" Height="108px" Width="600px" OnRowDeleting="gvDepartList_RowDeleting" RowDataBound="gvDepartList_RowDataRound"> <Columns> <asp:TemplateField HeaderText="部门名称" > <ItemTemplate> <asp:Label runat="server" style="text-align:center" Text='<%# Eval("DepartName") %>' /> </ItemTemplate> </asp:TemplateField> <asp:BoundField HeaderText="机构" DataField="BranchId" /> <asp:BoundField HeaderText="负责人" DataField="PrincipalUser" /> <asp:BoundField HeaderText="联系电话" DataField="ConnectTelNo" /> <asp:BoundField HeaderText="移动电话" DataField="ConnectMobileTelNo"/> <asp:BoundField HeaderText="传真" DataField="Faxes" /> <asp:TemplateField HeaderText="修改"> <ItemTemplate> <asp:ImageButton ID="ImageButton1" ImageUrl="../images/edit.gif" CommandArgument='<%#Eval("DepartId") %>' CommandName="delete" runat="server" /> </ItemTemplate> </asp:TemplateField> <asp:TemplateField HeaderText="删除"> <ItemTemplate> <asp:ImageButton ImageUrl="../images/delete.gif" CommandArgument='<%#Eval("DepartId") %>' CommandName="delete" runat="server" /> </ItemTemplate> </asp:TemplateField> </Columns> </asp:GridView> 二:在这个.aspx页面后台的Page_load事件中绑定数据。 复制代码 代码如下: protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { gvDepartList.DataSource= new DepartInfoManager().GetDepartInfos(-1); gvDepartList.DataBind(); } } 如果我们想添加一个DataGridView的光棒效果,就是每一行鼠标悬浮上去变动背景色啦。 复制代码 代码如下: /// <summary> /// 动态注册脚本(在GridView控件呈现之前) 光棒效果 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> protected void gvUsers_RowDataBound(object sender, GridViewRowEventArgs e) { //此处判断只有在数据行在进行脚本注册 if (e.Row.RowType == DataControlRowType.DataRow) { //光棒效果 e.Row.Attributes.Add("onmouseover","currentcolor=this.style.backgroundColor;this.style.backgroundColor='#6699ff'"); e.Row.Attributes.Add("onmouseout ", "this.style.backgroundColor=currentcolor"); LinkButton lnkbtnDel = e.Row.FindControl("lnkbtnDel") as LinkButton; lnkbtnDel.Attributes.Add("onclick", "return confirm('确定删除吗?')"); } } 现在重点来了,怎么一行的数据呢?既然是删除,我们肯定是要根据一条数据的ID来删除了,那么我们在Page_load方法中加入一段代码: 复制代码 代码如下: <asp:TemplateField HeaderText="删除"> <ItemTemplate> <asp:ImageButton ImageUrl="../images/delete.gif" CommandArgument='<%#Eval("DepartId") %>' CommandName="delete" runat="server" /> </ItemTemplate> </asp:TemplateField> 接下来就是后台操作代码了,可以看到这个DataGridView绑定了一个OnRowDeleting事件,这个事件就是用来删除的。 复制代码 代码如下: /// <summary> /// 删除选中的行 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> protected void gvDepartList_RowDeleting(object sender, GridViewDeleteEventArgs e) { ImageButton buttom = gvDepartList.Rows[e.RowIndex].FindControl("btnDelete") as ImageButton; string departId = buttom.CommandArgument.ToString(); if (manage.DeleteDepart(departId)) { Page.ClientScript.RegisterClientScriptBlock(this.GetType(), "alert", "<script>alert('删除成功!');</script>"); BindDepartInfos();//重新绑定数据 } else { Page.ClientScript.RegisterClientScriptBlock(this.GetType(), "alert", "<script>alert('删除失败!');</script>"); } } 为了更好的用户体验,我们可以不使用这个Page.ClientScript.RegisterClientScriptBlock(this.GetType(), "alert", "<script>alert('删除成功!');</script>"); |
请发表评论