![ASP.NET项目开发全程实录(第4版)](https://wfqqreader-1252317822.image.myqcloud.com/cover/589/26793589/b_26793589.jpg)
3.9 产品信息管理模块设计
3.9.1 产品信息管理模块概述
产品管理模块主要对公司的产品信息进行各种操作,其中主要包括添加产品信息、修改产品信息、删除产品信息和查询产品信息等操作。产品信息管理页面运行结果如图3.22所示。
![](https://epubservercos.yuewen.com/60F777/15253385804108706/epubprivate/OEBPS/Images/Figure-P159_9747.jpg?sign=1738930497-QiihhoU1rJGzLD7c0LpA4Oq0CNBbrio3-0-3c2e8ee21eead525c2712c801d817704)
图3.22 产品信息管理页面
3.9.2 产品信息管理模块技术分析
产品信息管理模块实现时,主要使用ADO.NET技术对产品信息进行添加、修改、删除和查询等操作,具体实现时,主要是通过调用ProductOperate类中的相关方法实现的。ProductOperate类是用户自定义的一个产品操作类,其中封装了与产品相关的信息及各种操作方法,它的实现原理与UserOperate类(用户操作类)类似,都是建立在数据层(DataBase.cs数据库操作类)的基础上。ProductOperate类的实现代码请参见本书附带资源包中的源代码,这里不再详细讲解。
3.9.3 产品信息管理模块实现过程
本模块使用的数据表:tb_Product
产品信息管理模块的具体实现步骤如下:
(1)新建一个基于MasterPage.master母版页的Web页面,命名为ProductManage.aspx,主要用于对产品信息进行添加、修改、删除和查询等操作,该页面中主要用到的控件如表3.12所示。
表3.12 产品信息管理页面主要用到的控件
![](https://epubservercos.yuewen.com/60F777/15253385804108706/epubprivate/OEBPS/Images/Figure-T159_33384.jpg?sign=1738930497-rO8MbPcV7BzPMo66ARJS8CtBjjExD5DR-0-7b683d5d90c980eab16ad84f18234d9c)
(2)在ProductManage.aspx页面中,首先创建公共类DataOperate和ProductOperate的对象,以便调用其中的方法,代码如下:
例程39 代码位置:资源包\TM\03\EnterpriseWeb\Manager\ProductManage.aspx.cs
DataOperate dataoperate = new DataOperate(); //创建DataOperate对象 ProductOperate productoperate = new ProductOperate(); //创建ProductOperate对象
ProductManage.aspx页面中自定义了一个BindInfo方法,该方法用来根据接收的类别编号和输入的查询条件获取指定的产品信息,并显示在GridView控件中。BindInfo方法的实现代码如下:
例程40 代码位置:资源包\TM\03\EnterpriseWeb\Manager\ProductManage.aspx.cs
![](https://epubservercos.yuewen.com/60F777/15253385804108706/epubprivate/OEBPS/Images/Figure-P160_33389.jpg?sign=1738930497-Vp6JhWtXMK41yy2ZnZnQn0WzuF1XUtZh-0-d2165ab5e455017f7921775b844dd5bc)
ProductManage.aspx页面加载时,调用自定义方法BindInfo在GridView控件中显示指定类别的产品信息,其实现代码如下:
例程41 代码位置:资源包\TM\03\EnterpriseWeb\Manager\ProductManage.aspx.cs
![](https://epubservercos.yuewen.com/60F777/15253385804108706/epubprivate/OEBPS/Images/Figure-P161_33393.jpg?sign=1738930497-jSQzuQammDpbAZmHiqNCtssZyPHh4fT0-0-5d57e0e715efad2c1670083f8034c169)
单击“添加”按钮,首先判断输入的产品名称是否为空,如果为空,则弹出信息提示,否则调用DataOperate类中的validateNum方法判断“价格”文本框中输入的是否为数字,如果是数字,则调用ProductOperate类中的AddProduct方法将产品信息添加到数据库中。“添加”按钮的Click事件代码如下:
例程42 代码位置:资源包\TM\03\EnterpriseWeb\Manager\ProductManage.aspx.cs
![](https://epubservercos.yuewen.com/60F777/15253385804108706/epubprivate/OEBPS/Images/Figure-P162_33395.jpg?sign=1738930497-Nvi1Hk4ilCMkzBhRppoXI5Thu056hYRI-0-ed762a65ad3de90da1e8e6eb2820e551)
![](https://epubservercos.yuewen.com/60F777/15253385804108706/epubprivate/OEBPS/Images/Figure-P163_33396.jpg?sign=1738930497-I5fCKHjVucIDyYbx5jvvqB9s5qruGYpy-0-5dd66318f50f095ffc66fb55f8d99e39)
当在GridView控件中单击“选择”超级链接时,将选中的产品信息显示在相应的文本框中,实现代码如下:
例程43 代码位置:资源包\TM\03\EnterpriseWeb\Manager\ProductManage.aspx.cs
![](https://epubservercos.yuewen.com/60F777/15253385804108706/epubprivate/OEBPS/Images/Figure-P163_33398.jpg?sign=1738930497-VeyKQJfSTxKAE23syWPYZiGLcgLi769L-0-db15b7eded5f4f398f3f6a7d11d4d7d6)
单击“修改”按钮,判断是否选中了要修改的产品,如果是,则调用ProductOperate类中的UpdataProduct方法修改指定的产品信息,否则弹出“请选择要修改的产品”信息提示。“修改”按钮的Click事件代码如下:
例程44 代码位置:资源包\TM\03\EnterpriseWeb\Manager\ProductManage.aspx.cs
![](https://epubservercos.yuewen.com/60F777/15253385804108706/epubprivate/OEBPS/Images/Figure-P163_33400.jpg?sign=1738930497-vPM0yiXVd3wxYAjwJwqfuF9MXwqzrwtB-0-775e6c1671676db26baa0a3c1fbbfd7a)
当在GridView控件中单击“删除”超级链接时,调用ProductOperate类中的DeleteProduct方法删除选中的产品信息,实现代码如下:
例程45 代码位置:资源包\TM\03\EnterpriseWeb\Manager\ProductManage.aspx.cs
![](https://epubservercos.yuewen.com/60F777/15253385804108706/epubprivate/OEBPS/Images/Figure-P164_33403.jpg?sign=1738930497-IS2mWyOnjq2IFJqkt99PJPvXPmn4cOfW-0-d617cf6f1404a3ab15dd6ebc4c7f3fd6)
单击“查询”按钮,调用自定义方法BindInfo按指定条件查询信息,并显示在GridView控件中。“查询”按钮的Click事件代码如下:
例程46 代码位置:资源包\TM\03\EnterpriseWeb\Manager\ProductManage.aspx.cs
![](https://epubservercos.yuewen.com/60F777/15253385804108706/epubprivate/OEBPS/Images/Figure-P164_33405.jpg?sign=1738930497-7I9jTuTMD3drVm9aKHpqs3zVHJ2oxm2H-0-7b18ff003ccbb9fa5ebf7f41c1d00eb2)