ASP.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)
最后效果:

绑值GridView
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 换页不报错
到此这篇关于ASP.NET学习中常见错误总结归纳的文章就介绍到这了,更多相关ASP.NET 常见错误内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
.NET 6新特性试用Timer类之PeriodicTimer
这篇文章主要介绍了.NET 6新特性试用Timer类之PeriodicTimer,PeriodicTimer与其他Timer需要创建事件回调不同,下,下面文章详细介绍PeriodicTimer的使用方式,需要的朋友可以参考一下2022-02-02
ASP.NET webUploader上传大视频文件相关web.config配置
本文主要介绍了webUploader上传大视频文件相关web.config的配置。具有一定的参考价值,下面跟着小编一起来看下吧2017-01-01
使用Asp.net Mvc3 Razor视图方式扩展JQuery UI Widgets方法介绍
jquery easyui grid或者extjs grid,jtable的代码非常简洁、对于grid功能要求不是很复杂的情况下,强烈推荐大家使用2012-11-11
在 ASP.NET Core 中为 gRPC 服务添加全局异常处理
这篇文章主要介绍了在 ASP.NET Core 中为 gRPC 服务添加全局异常处理 ,在 ASP.NET Core 中使用 GRPC.ASPNETCore 工具包写 gRPC 服务,想实现 gRPC 的异常全局拦截,下面一起来看看文中的详细内容吧2022-01-01
asp.net mvc路由篇 如何找到 IHttpHandler方法介绍
学习是使用asp.net已经有很长一段时间了,现在就来分析一下mvc的整过过程吧。个人计划写一个mvc系列的博文,仅从源代码的角度来分析mvc。在接触mvc时我们一定会经历路由,那么路由这东东是怎么搞出来的啊2012-11-11
ASP.NET MVC Web API HttpClient简介
依稀还记得那个时候用WebClient,HttpWebRequest来发送一个请求,现在ASP.NET MVC4中自带了一个类HttpClient;需要的朋友可以参考下2012-11-11


最新评论