C#之Repeater控件
想起来,公司的aspx页面前台数据展示除了datagrid以为还有Repeater控件,现在温习温习这个控件
1:// 从一个数据项中获得相应的控件
TextBox txtTitle = (TextBox)e.Item.FindControl("txtTitle");
得记住这样获取值的方式,(控件类型)的转换
2:CheckBox chkInTheaters = (CheckBox)e.Item.FindControl("chkInTheaters");
<asp:Repeater ID="userRepeat" runat="server" OnItemCommand="userRepeat_ItemCommand" OnItemDataBound="userRepeat_ItemDataBound">
标红的是 Repeater控件命令事件
<ItemTemplate> <tr>
<td><%#Eval( "ID") %> </td> <td><%#Eval( "Title") %> </td> <td><%#Eval( "Cont") %></td> <td><%#Eval( "Keys") %></td> <td><%#Eval( "Des") %></td> <td><%#Eval( "AddTime") %></td> </tr> </ItemTemplate>
<asp:LinkButton ID="LinkButton1" runat="server" CommandName="Del" CommandArgument='<%#Eval("ID") %>'>删除</asp:LinkButton> <asp:LinkButton ID="LinkButton2" runat="server" CommandName="Update" CommandArgument='<%#Eval("ID") %>'>修改</asp:LinkButton> <asp:Label ID="Label1" runat="server" Text='<%#Eval("NewID") %>' Visible="false"></asp:Label> <asp:LinkButton ID="LinkButton1" runat="server" CssClass="btn btn82 btn_del" CommandName="del" OnClientClick="return confirm('要删除吗?')">删除</asp:LinkButton> <asp:Label ID="Label2" runat="server" Text='<%#Eval("NewID") %>' Visible="false"></asp:Label> <asp:LinkButton ID="LinkButton2" runat="server" CommandName="Update" CommandArgument='<%#Eval("NewID")%>'>修改</asp:LinkButton>
前台代码通过设置控件的CommandArgument属性来传递后台所需要判断的id号。
两种不同的颜色相互对应,当点击删除时,获取"Del"的指令 然后获取到要删除数据的ID值
if(e.CommandName == "Del") { //string strid = ((Label)e.Item.FindControl("Label1")).Text; // int Id = Convert.ToInt32(strid); int id = Convert.ToInt32(e.CommandArgument.ToString()); }
绑定数据:
/// <summary> /// 将数据源绑定Repeater控件上 /// </summary> private void DataBindToRepeater() { //使用using语句进行数据库连接 using(SqlConnection sqlCon = new SqlConnection("server=.;database=MyBlog;uid=sa;pwd=1")) { sqlCon.Open(); //打开数据库连接 SqlCommand sqlcom = new SqlCommand(); //创建数据库命令对象 sqlcom.CommandText = "select * from match"; //为命令对象指定执行语句 sqlcom.Connection = sqlCon; //为命令对象指定连接对象 this.userRepeat.DataSource = sqlcom.ExecuteReader(); //为Repeater对象指定数据源 this.userRepeat.DataBind(); //绑定数据源 } }
protected void userRepeat_ItemCommand(object source, RepeaterCommandEventArgs e) { //获取命令文本,判断发出的命令为何种类型,根据命令类型调用事件 if(e.CommandName == "Edit") //编辑命令 { id = int.Parse(e.CommandArgument.ToString()); //获取命令ID号 } else if(e.CommandName == "Cancel") //取消更新命令 { id = -1; } else if(e.CommandName == "Delete") //删除行内容命令 { id = int.Parse(e.CommandArgument.ToString()); //获取删除行的ID号 //删除选定的行,并重新指定绑定操作 this.DeleteRepeater(id); } else if(e.CommandName == "Update") //更新行内容命令 { //获取更新行的内容和ID号 string strText = ((TextBox) e.Item.FindControl("txtName")).Text.Trim(); int intId = int.Parse(((Label) e.Item.FindControl("lblID")).Text); //更新Repeater控件的内容 this.UpdateRepeater(strText, intId); } //重新绑定控件上的内容 this.DataBindToRepeater(); }
SqlCommand sqlcom = new SqlCommand(); //创建数据库命令对象 sqlcom.CommandText = "update match set name=@str where id=@id"; //为命令对象指定执行语句 sqlcom.Connection = sqlCon; //为命令对象指定连接对象 //创建参数集合,并向sqlcom中添加参数集合 SqlParameter[] sqlParam = { new SqlParameter("@str", strText), new SqlParameter("@id", intId) }; sqlcom.Parameters.AddRange(sqlParam);
人各有命,上天注定,有人天生为王,有人落草为寇。脚下的路,如果不是你自己的选择,那么旅程的终点在哪,也没人知道。你会走到哪,会遇到谁,都不一定。