ASP.NET学生常犯错误

本文涉及的产品
对象存储 OSS,20GB 3个月
对象存储 OSS,恶意文件检测 1000次 1年
对象存储OSS,敏感数据保护2.0 200GB 1年
简介: 自己在学习.NET中常犯的错误(持续更新

# 前言 自己在学习.NET中常犯的错误(持续更新) --- ### 下拉框绑值 ```csharp 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) 最后效果: ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/20210517151544165.gif#pic_center) --- ### 绑值GridView ```csharp public void jiaz() { this.GridView1.DataSource = dbl.show(); this.GridView1.DataBind(); } ``` DataSource:数据源,绑定sql语言可以显示数据 DataBind:绑定数据才可以显示出来,是一个函数 最后效果: ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/20210517152135385.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ2ODc0MzI3,size_16,color_FFFFFF,t_70) --- ### 删除数据 - 点击删除 > CommandAgument和CommandName 配合一起使用,一般习惯用于**删除** > 会在RowCommand事件执行 先绑定ID ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/20210517152512595.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ2ODc0MzI3,size_16,color_FFFFFF,t_70) 再绑定CommandName ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/20210517152938263.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ2ODc0MzI3,size_16,color_FFFFFF,t_70) 进入Rowcommand事件里面 ```csharp 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(""); jiaz(); } else { Response.Write(""); } } } ``` > **e.CommandName=="del"** RowCommand无论怎么样都会先来这里,所以判断一下是不是要执行删除操作,根据e.CommandName=="del" > **int id = int.Parse(e.CommandArgument.ToString());** 删除执行的SQL语句是要根据ID唯一标识列来进行有目标的 --- ### 修改 - 点击修改 > 修改CommandName为update,为了激发updateing事件 ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/20210517154821882.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ2ODc0MzI3,size_16,color_FFFFFF,t_70) 绑定ID,这里是键值对 ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/20210517154955753.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQ2ODc0MzI3,size_16,color_FFFFFF,t_70) > 为什么不绑定commandAgument呢,因为上面说了commandAgument,是要去Rowcommand事件配合使用的,我们把CommandName修改成为update,是要去Rowupdating事件 ```csharp 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(""); jiaz(); } else { Response.Write(""); } } ``` > **int id = int.Parse(this.GridView1.DataKeys[e.RowIndex]["DeviceID"].ToString());** 修改SQL语句也是要获取修改的唯一标识列 这个GridView1的DataKeys [e.RowIndex] ["DeviceID"]:当前行的数据库标识列 --- ### 修改赋值到另外一个页面 ```csharp 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(找控件) --- ### 修改赋值到另外一个页面绑定值 **文本框绑定值** ```csharp this.TextBox2.Text = Session["BookName"].ToString(); ``` **下拉框绑定值** ```csharp if (Session["BookiS"].ToString().Contains("是")) { this.DropDownList1.SelectedIndex = 0; } else { this.DropDownList1.SelectedIndex = 1; } ``` > 判断session里面是否包含这个值 > **this.DropDownList1.SelectedIndex = 0;** SelectedIndex = 0 代表 展示的是第一个 --- ### 换页不报错 ```csharp protected void GridView1_PageIndexChanging(object sender, GridViewPageEventArgs e) { this.GridView1.PageIndex = e.NewPageIndex; //换页不报错 jiazGridview(); } ``` Gridview 换页不报错 ---
相关实践学习
通义万相文本绘图与人像美化
本解决方案展示了如何利用自研的通义万相AIGC技术在Web服务中实现先进的图像生成。
相关文章
|
运维 Cloud Native Devops
云原生 DevOps CI/CD 概述
【1月更文挑战第7天】云原生 DevOps CI/CD 概述
|
图形学 Windows
Unity调用Windows弹框、提示框(确认与否,中文)
Unity调用Windows弹提示框 本文提供全流程,中文翻译。 Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 —— 高分辨率用户请根据需求调整网页缩放比例) Chinar...
3922 0
|
11月前
|
Java
Java开发实现图片地址检验,如果无法找到资源则使用默认图片,如何编码?
【10月更文挑战第14天】Java开发实现图片地址检验,如果无法找到资源则使用默认图片,如何编码?
213 2
|
SQL 人工智能 搜索推荐
如何有效利用ChatGPT写代码?
如何有效利用ChatGPT写代码?
183 1
|
11月前
|
设计模式 监控 安全
Python多线程编程:特性、挑战与最佳实践
Python多线程编程:特性、挑战与最佳实践
155 0
|
存储 负载均衡 算法
从海量数据中挖出TOP100热词,这个算法太绝了!
小米,一位热爱技术的29岁程序员,今天探讨如何在海量搜索词汇中找出最热的TOP100词汇。面对包含数百亿词汇的大文件,小米介绍了一种实用的方法:通过哈希分流将大文件拆分成小文件,接着利用哈希表统计词频,并运用小根堆选出每个小文件的TOP100词汇。最后通过外排序或再次使用小根堆选出全局TOP100。此外还提出了并行处理、内存优化及数据压缩等优化手段。这一系列技巧能有效应对大数据处理挑战。
206 9
|
12月前
|
安全 新能源
碳捕获与封存技术:减排的有效途径
【9月更文挑战第29天】全球气候变化日益严峻,碳捕获与封存技术(CCS)作为减排新兴技术,通过捕集、运输和封存三个环节,有效减少二氧化碳排放。本文详细探讨了CCS的技术原理、应用前景及挑战,指出其在减缓气候变化、促进低碳经济和多样化场景中的重要作用,并提出了技术成熟度提升、成本降低及安全性监管等方面的解决方案。
|
11月前
|
光互联
常见网络电缆类型详解
【10月更文挑战第14天】
276 0
|
弹性计算 移动开发 Serverless
Serverless 应用引擎操作报错合集之部署stable启动时出现:Function instance health check failed on port 5000 in 120 seconds该怎么解决
Serverless 应用引擎(SAE)是阿里云提供的Serverless PaaS平台,支持Spring Cloud、Dubbo、HSF等主流微服务框架,简化应用的部署、运维和弹性伸缩。在使用SAE过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
182 0
|
异构计算
实验三 基于FPGA的数码管动态扫描电路设计 quartus/数码管/电路模块设计(上)
实验三 基于FPGA的数码管动态扫描电路设计 quartus/数码管/电路模块设计(上)
1359 0
实验三 基于FPGA的数码管动态扫描电路设计 quartus/数码管/电路模块设计(上)