ASP.NET学习中常见错误总结归纳

 更新时间:2021年09月26日 15:15:57   作者:意愿三七  
这篇文章主要介绍了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框架类型系统设计要点

    一文透彻详解.NET框架类型系统设计要点

    这篇文章主要为大家透彻详解了选择.NET框架的n个理由,本系列的第一篇文章全面概述了平台的支柱和设计要点,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05
  • upload上传单张图片

    upload上传单张图片

    这篇文章主要介绍了upload上传单张图片的代码,需要的朋友可以参考下。
    2015-07-07
  • .NET新能源汽车锂电池检测程序UI挂死问题分析

    .NET新能源汽车锂电池检测程序UI挂死问题分析

    这篇文章主要为大家介绍了.NET新能源汽车锂电池检测程序UI挂死问题分析 ,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • .Net性能调优-ArrayPool详情

    .Net性能调优-ArrayPool详情

    ArrayPool具有高性能 托管 数组缓冲池,可重复使用,用 租用 空间的方式代替 重新分配 数组空间的行为的特点及可以在频繁创建和销毁数组的情况下 提高性能 ,减少垃圾回收器的压力的优点,下面文章内容将详细对其做介绍,需要的朋友可以参考一下
    2021-09-09
  • ASP.NET Core如何注入多个服务实现类

    ASP.NET Core如何注入多个服务实现类

    这篇文章主要介绍了ASP.NET Core如何注入多个服务实现类的相关资料,需要的朋友可以参考下面文章的具体内容
    2021-09-09
  • ASP.NET Core MVC 依赖注入View与Controller

    ASP.NET Core MVC 依赖注入View与Controller

    本文重点给大家介绍的是ASP.NET Core MVC 之依赖注入 View 和ASP.NET Core MVC 之依赖注入 Controller的相关资料,需要的小伙伴可以参考下面文章具体内容
    2021-09-09
  • 一个经典的ADO.NET入门例子

    一个经典的ADO.NET入门例子

    一个经典的ADO.NET入门例子...
    2006-07-07
  • ASP.NET Web API教程 创建域模型的方法详细介绍

    ASP.NET Web API教程 创建域模型的方法详细介绍

    本文将介绍几种常见的创建域模型的方法,有需要的朋友可以适当的参考
    2012-11-11
  • ASP.NET Core WebSocket集群实现思路详解

    ASP.NET Core WebSocket集群实现思路详解

    这篇文章主要为大家介绍了ASP.NET Core WebSocket集群实现思路详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • 在 ASP.NET Core 中为 gRPC 服务添加全局异常处理

    在 ASP.NET Core 中为 gRPC 服务添加全局异常处理

    这篇文章主要介绍了在 ASP.NET Core 中为 gRPC 服务添加全局异常处理 ,在 ASP.NET Core 中使用 GRPC.ASPNETCore 工具包写 gRPC 服务,想实现 gRPC 的异常全局拦截,下面一起来看看文中的详细内容吧
    2022-01-01

最新评论