时间:2021-11-23 11:45:27 | 栏目:.NET代码 | 点击:次
自己在学习.NET中常犯的错误(持续更新)
public void ddlist() { this.DropDownList1.DataTextField = "DeviceName"; this.DropDownList1.DataValueField = "DeviceID"; this.DropDownList1.DataSource = dbl.ddlist(); this.DropDownList1.DataBind(); this.DropDownList1.Items.Insert(0, new ListItem("全部", "0")); }
this.DropDownList1.DataTextField = “DeviceName”;
DataTextField :显示给用户看的数据库列
DataValueField:绑定数据源等于绑定唯一标识列
DataSource:数据源,绑定sql语言可以显示数据
DataBind:绑定数据才可以显示出来,是一个函数
Items.Insert(0, new ListItem(“全部”, “0”));
ltems表示集合
insert()两个参数 (int index,Ltems item)
最后效果:
public void jiaz() { this.GridView1.DataSource = dbl.show(); this.GridView1.DataBind(); }
DataSource:数据源,绑定sql语言可以显示数据
DataBind:绑定数据才可以显示出来,是一个函数
最后效果:
CommandAgument和CommandName 配合一起使用,一般习惯用于删除
会在RowCommand事件执行
先绑定ID
再绑定CommandName
进入Rowcommand事件里面
protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e) { if (e.CommandName=="del") { int id = int.Parse(e.CommandArgument.ToString()); bool b1 = dbl.del(id); if (b1) { Response.Write("<script>alert('删除成功')</script>"); jiaz(); } else { Response.Write("<script>alert('删除失败')</script>"); } } }
e.CommandName=="del"
RowCommand无论怎么样都会先来这里,所以判断一下是不是要执行删除操作,根据e.CommandName==“del”
int id = int.Parse(e.CommandArgument.ToString());
删除执行的SQL语句是要根据ID唯一标识列来进行有目标的
修改CommandName为update,为了激发updateing事件
绑定ID,这里是键值对
为什么不绑定commandAgument呢,因为上面说了commandAgument,是要去Rowcommand事件配合使用的,我们把CommandName修改成为update,是要去Rowupdating事件
protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e) { int id = int.Parse(this.GridView1.DataKeys[e.RowIndex]["DeviceID"].ToString()); bool b1 = dbl.up(id); if (b1) { Response.Write("<script>alert('修改成功')</script>"); jiaz(); } else { Response.Write("<script>alert('修改失败')</script>"); } }
int id = int.Parse(this.GridView1.DataKeys[e.RowIndex][“DeviceID”].ToString());
修改SQL语句也是要获取修改的唯一标识列
这个GridView1的DataKeys
[e.RowIndex] [“DeviceID”]:当前行的数据库标识列
Session["ID"] = this.GridView1.DataKeys[e.RowIndex]["BookID"].ToString(); Label Booksname = (Label)this.GridView1.Rows[e. RowIndex].FindControl("Label2"); Session["BookName"] = Booksname.Text; Response.Redirect("add.aspx");
Session[“ID”] = this.GridView1.DataKeys[e.RowIndex][“BookID”].ToString();
找到的ID赋值给session
Label Booksname = (Label)this.GridView1.Rows[e. RowIndex].FindControl(“Label2”);
找当前行的Label2控件
Session[“BookName”] = Booksname.Text;
把找到控件的值文本传给session
Lable是类型,看Gridview是什么控件就转换为什么类型
FindControl(找控件)
文本框绑定值
this.TextBox2.Text = Session["BookName"].ToString();
下拉框绑定值
if (Session["BookiS"].ToString().Contains("是")) { this.DropDownList1.SelectedIndex = 0; } else { this.DropDownList1.SelectedIndex = 1; }
判断session里面是否包含这个值
this.DropDownList1.SelectedIndex = 0;
SelectedIndex = 0 代表 展示的是第一个
protected void GridView1_PageIndexChanging(object sender, GridViewPageEventArgs e) { this.GridView1.PageIndex = e.NewPageIndex; //换页不报错 jiazGridview(); }
Gridview 换页不报错