超市进销存管理系统武晓娟乔梦莎_第1页
超市进销存管理系统武晓娟乔梦莎_第2页
超市进销存管理系统武晓娟乔梦莎_第3页
超市进销存管理系统武晓娟乔梦莎_第4页
超市进销存管理系统武晓娟乔梦莎_第5页
已阅读5页,还剩35页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、超市进销存管理系统专 业 _班 级 _姓 名 _指 导 老 师 _邯郸职业技术学院年 月 日摘 要 随着科学技术的不断提高,计算机科学日渐成熟,它已经深入到日常工作和生活的方方面面,比如文字处理、信息管理、辅助设计、图形图像处理、教育培训以及游戏娱乐等。虽然现在世界上已经充满了多如牛毛的各种软件,但它们依然不能满足用户的各种特殊需要,人们还不得不开发适合自己特殊需求的软件。以前开发Windows应用软件是专业人员的工作,需要掌握许多专业知识和经过特殊的培训才能胜任。现在不同了,即使你没有接受过严格的程序设计训练,使用Visual Basic也一样能够开发出功能强大、适合自己特殊需求的应用程序了

2、。Visual Basic继承了Basic语言易学易用的特点,特别适合于初学者学习Windows系统编程。 超市进销存管理系统用计算机管理超市库存进出管理的一种计算机应用技术的创新,在计算机还未普及之前库存管理都是由工作人员手工书写的方式来操作的.现在一般的超市都采用计算机智能化管理,采用计算机作为工具的实用的计算机超市库存管理程序来帮助管理员进行更有效的超市库存管理工作。超市进销存管理系统是典型的信息管理系统(MIS),其开发主要包括后台数据库的建立和维护以及前端应用程序的开发两个方面。对于前者要求建立起数据一致性和完整性强、数据安全性好的库。而对于后者则要求应用程序功能完备,易使用等特点。

3、 经过分析,我们使用 MICROSOFT公司的 VISUAL BASIC开发工具,利用其提供的各种面向对象的开发工具,尤其是数据窗口这一能方便而简洁操纵数据库的智能化对象,首先在短时间内建立系统应用原型,然后,对初始原型系统进行需求迭代,不断修正和改进,直到形成用户满意的可行系统。因为本人能力有限,加上时间紧迫,所以设计出来的本系统可能功能比较简单,另外本系统是单机版,不能实现网络互联操作,这些都有待于我在以后的工作学习中进一步改进。关键字:超市进销存管理,MIS,visual basic ,数据库AbstractAs science and technology continue to im

4、prove, computer science increasingly mature, It has to go down to the daily work and life, such as word processing, information management, aided design, graphics and video processing, as well as education and training game entertainment. although now the world has been filled with an over-abundance

5、 of software, but they still can not meet the special needs of the various users, it also had to develop software suited to their particular needs. Professional Windows application software development before the work is needed in many professional knowledge and competence through special training.

6、Different now, even if you have not received strict procedures designed training, the use of Visual Basic also like to develop a powerful, and suited to their special needs applications. Visual Basic inherited Basic language learn user-friendly features, and are particularly suited to new learner le

7、arning Windows system programming. Supermarket Jinxiaocun management system using computer management Supermarket stocks a computer application and management of technology innovation in the computer before the inventory management are not yet universal manual written by the staff to operate. Superm

8、arkets are now generally used computer intelligent management, using the computer as a tool for computer supermarket inventory management procedures to help managers more effectively supermarket inventory management. Supermarket Jinxiaocun management system is a typical management information system

9、 (MIS), including its main development background to the establishment and maintenance of the database and front-end application development 2. The request for the establishment of strong data consistency and integrity, good for the security of the data. For the latter request applications functions

10、, such as easy to use features. After analysis, we use Microsoft visual basic development tool companies, the use of its various object-oriented development tools, especially data that can be easily accessible and concise window manipulation database intelligent objects, the first prototype applicat

11、ion system in a short time and then, computation of the initial prototype system needs to constantly revise and improve until the formation of a viable system of user satisfaction. Because I limited capacity, coupled with time constraints, it designed the system may function relatively simple, and t

12、he system is single edition, not Internet operations network, which I have yet to learn that in future work to further improve. keyword : Supermarket Jinxiaocun management MIS,visual basic database目录第一章 引言411 课题背景412 系统简介51. 3 开发软件介绍6第二章 系统的分析821 系统开发的目标和思想922 系统的可行性分析13第三章 系统的设计1831 系统的功能结构设计1832 系

13、统的数据库设计 1933 界面设计与代码设计23第四章 结束语 46参考文献47 致谢49第1章 引言1.1 课题背景超市进销存管理系统用计算机管理超市库存进出管理的一种计算机应用技术的创新,在计算机还未普及之前库存管理都是由工作人员手工书写的方式来操作的.现在一般的超市都采用计算机智能化管理,采用计算机作为工具的实用的计算机超市库存管理程序来帮助管理员进行更有效的超市库存管理工作。超市进销存管理系统是典型的信息管理系统(MIS),其开发主要包括后台数据库的建立和维护以及前端应用程序的开发两个方面。对于前者要求建立起数据一致性和完整性强、数据安全性好的库。而对于后者则要求应用程序功能完备,易使

14、用等特点。1.2系统简介 本系统采用visual basic与Access作为数据库的方式编写,主要服务于超市库存管理人员的日常工作. 主要几大功能模块构成如下: 功能模块一是商品类型管理:添加商品类型,修改商品类型,删除商品类型 功能模块二是商品管理:添加商品信息,修改商品信息,删除商品信息 功能模块三是进货管理:添加进货管理,修改进货管理,删除进货管理 功能模块四是销售管理: 添加销售管理,修改销售管理,删除销售管理 功能模块五是报损管理: 添加报损管理,修改报损管理,删除报损管理1.3开发软件介绍Visual Basic 6.0是Micrsoft公司出品的开发工具,Visual Basi

15、c是一种可视化的,面向对象的Windows开发语言,它具有易用,通用和开发效率高的特点。随着微软对它不断地改进以及计算机本身性能的提高,使得Visual Basic越来越适合一般的应用程序开发。正如Bill Gate所说,世界上绝大多数的Windows应用程序是用Visual Basic编写的。在众多的开发工具中,我们为什么要选择Visual Basic6.0呢?因为VB具有众多其它开发工具所没有的优点!具体介绍如下:优点一:开发的高效优点二:语言的高效优点三:编译的高效优点四:执行的高效优点五:维护的高效基于以上理由,我们毫不忧郁的选择了VB6.0做为我们的开发工具!主要的控件及其基本属性,

16、事件简介1.命令按钮类的控件:1) Caption属性:用来显示在控件上的标题。2) Enable属性:控制控件的激活状态灰色或可用。3) Appearance属性:值为1时,则以3D效果显示该控件,0则不然。4) Backcolor属性:用来改变在按钮上显示图像的背景色。5) Cancel属性:该属性决定按钮是否为一个”取消”按钮。6) Default属性:决定哪一个命令按钮控件是窗体的缺省命令按钮.7) Font属性:控制各种文字字体类型.8) Left,top,height,width属性:设定控件的位置与大小.9) Style,picture属性:决定按钮的显示方式是否为图像形式出现.

17、10) Visible属性:确定控件运行时是否为可见.11) Index属性:当控件为一控件数组时,此属性值为该控件在数组的下标值.12) DownPicture属性:设置/返回一个对图片的引用,该图片在按钮被单击处于压下状态时显示。13) DisabledPicture属性:设置/返回一个对图片的引用,该图片在控件无效时显示在控件中。14) MaskColor属性:设置/返回一个在按钮的图片中作为“掩码“的的颜色15) Picture属性:设置返回commandButton控件中要显示的图片。2.命令按钮类的事件:1) 单击事件Click事件(1) 触发与适用此事件是在一个命令按钮对象上按下

18、然后释放一个鼠标按钮时发生。命令按钮的Click事件仅对当单击鼠标时发生。(2) 事件处理过程按钮单击事件的处理过程为: Private Sub object-Click(Index As Integer)其中Object为引发该事件的对象名称。如果是命令按钮的控件是数组,则需要使用Index参数标识该控件。2) 获得焦点GotFocus事件(1) 触发与适用 当命令按钮获得焦点产生该事件,获得焦点可以通过诸如Tab切换或单击对象之类的用户动作,或在代码中用SetFocus方法改变焦点来实现。(2) 事件处理过程命令按钮GotFoucs事件处理过程为:Private Sub Object-Go

19、tFocus(Index As Integer)3) LostFocus事件:当一个对象失去焦点时发生4) KeyDown事件:当命令按钮具有焦点时按下一个键时发生5) KeyUp事件:当命令按钮具有焦点时释放一个键时发生。6) KeyPress事件:当用户按下或松开一个ANSI键时发生。7) MouseDown事件:当在命令按钮上按下鼠标按钮时发生。8) MouseMove事件:当命令按钮上移动鼠标时发生。9) MouseUp事件:当在命令按钮上释放鼠标按钮时发生。3.标签框类的控件类的控件:1) Caption属性:在应用程序界面上加入说明。2)Autosize属性:决定控件是否自动改变大

20、小以显示其全部内容。3)Backstyle属性:用以指示标签是否透明.4)Bordstyle属性:用以设定控件是否有边框。4.文本框类的控件:1)Text属性:通过像text属性赋值的方法来改变该属性的值。2)Maxlength属性:该属性设定在文本框控件中能够输入的最大字符数。3)Multline属性:该属性设定text字符串中是否接受换行符。4)Scrollbars属性:该属性决定是否为文本框加滚动条。5)Passwordchar属性:该属性设定输入文本的特殊显示字符,在设计密码程序时非常有用。6)Change事件属性:文本框的内容发生改变时,相应的控件之间发生相应的改变,具有即时性。7)

21、Keypress:事件由用户在文本框控件中按任意键触发。8)Alignment属性:设定控件中的文本对其方式9)Appearance属性:设定一个对象在运行时是否可以3D效果显示。10)BackColor属性:设置返回背景色11)BorderStyle属性:设置对象的边框样式12)DataField属性:设定数据使用者将被绑定到的字段名13)DataFormat属性:设定DataFormat对象,用于数据绑定14)DataMember属性:从数据供应程序提供的几个数据成员中返回/设定一个特定的数据成员15)DataSource属性:设定控件绑定的一个数据源16) DragIcon属性:设定图标

22、,它将在拖放操作中作为指针显示17) DragMode模式:设定一个值,确定在拖放操作中所用方式18) Enabled属性:设置/返回运行时TextBox是否相应用户事件19) Font属性:设置/返回字体属性20) ForeColor属性:设置/返回文本的前景色21) Height属性:设置/返回TextBox的高度22) IMEMode属性:设置/返回数值用来确定输入方法编辑器的状态23) Index属性:设置/返回唯一的标识控件数组中该控件的编号24) Left属性:设置/返回TextBox控件的水平位置25) Locked属性:设置/返回TextBox中文本是否可编辑26) LinkI

23、tem属性:设置/返回DDE与另一个应用程序会话时,传给接受端的数据27) MaxLength属性:设置/返回一个值,指定在TextBox控件中能够输入的字符最大值28) MouseIcon属性:设置/返回自定义鼠标的图标29) Top属性:设置/返回TextBox控件的垂直位置30) Tag属性:存储过程所需的附加数据5.文本框类的事件:1) Change事件:当改变文本框内容时发生2) Click事件:鼠标单击控件时发生3) DblClick事件:用鼠标左键双击控件时发生4) DragDrop事件:在一个完整的拖放动作完成或使用Drag方法,并将其Action参数设置为2时发生5) Dra

24、gOver事件:在拖放操作正在进行时发生6) GotFocus事件:当一个命令按钮获得焦点时发生7) LinkClose事件:当一个DDE对话结束时发生8) LinkError事件:当一个DDE对话框过程中出现错误时,该事件发生9) KeyDown事件:当命令按钮具有焦点时按下一个键时发生10) Validate事件:在焦点转换到另一个控件之前发生,此时该控件的Causes Validation 属性值设置为True6.单选按钮类的控件:1)Caption属性:显示在控件上的文本,是单选按钮的标题。2)Alignment属性:决定单选按钮的标题在控件上的位置。3)Enable属性:该控件为灰色

25、时为false,表示运行时不可用。4)Index属性:属性值表示为单选按钮组成的控件中某个按钮的索引值。5)Tabindex属性:建立控件时,vb自动为其分配一个tabindex值,利用tab键可以在控件之间切换焦点。6)Value属性:反映控件状态的属性,返回true表示已选择了该按钮。7)Appearance 属性:设置/返回一个对象在运行时是否以3D效果显示。8)BackColor 属性:设置/返回背景色。9)Container 属性:设置/返回Form上的控件属性。10)DataField 属性:设置/返回数据使用者将被绑定到的字段名。11)DataFormat 属性:设置/返回Dat

26、aFormat对象,一个绑定对象将附加到它。12)DisabledPicture 属性:设置/返回一个对图像的引用,该图片在控件无效时显示在控件中。13)DownPicture 属性:设置/返回一个对图片的引用,该图片在控件单击下处于压下状态时显示。14)DragMode 属性:设置/返回一个值,确定在拖放操作中所用的方式。15)Font 属性:设置/返回字体属性。16)FontBold 属性:设置/返回字体粗体样式。17)FontItalic 属性:设置/返回字体斜体样式。 18)FontStrikethru 属性:设置/返回字体删除线样式。19)FontUnderLine 属性:设置/返回

27、字体下划线样式。20)FontName 属性:设置/返回控件中显示文本所用的字体大小。21)FontSize 属性:设置/返回控件中显示文本所用的字体大小22)Height 属性:设置/返回控件的高度。23)MaskColor 属性:设置/返回一个在控件的图片中作为掩码的颜色。24)MousePointer 属性:设置/返回一个值,该值指示在运行时当鼠标移动到对象上时显示的指针类型。7.单选按钮类的常用事件:1)Click 事件:鼠标单击控件时发生。2)DbClick事件: 当在一个对象上按下和释放鼠标按钮并再次按下和释放按钮时,该事件发生。3)DragDrop事件:在一个完整的拖放动作或使用

28、Drag方法,并将其Action参数设置位2时,该事件发生。4)DragOver事件: 在拖放操作正在进行时发生。5)GotFocus事件: 当获的对象焦点时发生。6)LostFocus事件:当对象失去焦点时发生。7)KeyDown事件:当控件具有焦点时按下一个键时发生。8)KeyUp事件: 当控件具有焦点时释放一个键时发生。9)KeyPress事件:当用户按下或释放ANSI一个键时发生。10)MouseDown事件:当在控件上按下鼠标键时发生。11)MouseMove事件:在控件上移动鼠标时发生。12)MouseUp事件:在控件上释放鼠标时发生。8.复选按钮类的控件:1)Caption属性:

29、缺省为check1。2)Index属性:该属性值为复选框控件数组的下标.3)Value属性:value为0表空白,为1表勾号,为2表示灰色勾号.4)Container属性:Form控件上的容器。5)DataChangeed属性:设置/返回一个值,指出被绑定的控件中的数据已经被某进程修改。6)DataField属性:设置或返回数据使用者将被绑定到的字段名。7)DataFormat 属性:设置或返回DataFormat对象,用于数据绑定。8)Datasource属性:设置或返回控件绑定的一个数据源。9)DisabledPicture属性:设置或返回一个对图片的引用,该图片在控件无效时显示在控件中。

30、10)DownPicture 属性:设置或返回一个对图片的引用,该图片在控件被单击处于压下状态时显示。11)DragIcon属性:设置或返回图标,它将在拖放操作中做为指针显示。12)DragMode属性:设置返回一个值,确定在拖放操作中所用方式。13)Font属性:设置或返回字体的属性。14)Name属性:设置或返回控件的标识名。15)Value属性:设置或返回控件的状态。9.复选按钮类的控件的基本事件:1)Click事件:鼠标单击控件时发生。2)DragDrop事件:在一个完整的拖放动作完成或使用Drag方法,并将其Action参数设置为2时发生。3)DragOver事件:在拖放操作正在进行

31、时发生。4)GotFocus事件:在对象获的焦点时发生。,5)OLECompleteDrag事件:当源部件被放到目标时发生,并通知源部件拖放操作被执行或取消。6)OLEDragDrag事件:当源部件决定放操作能发生,却源部件被放到目标部件时,此事件发生。10.框架类的控件:1) List属性:列表框控件的表项是使用数组的方式保存,数组的每一个元素存储列表控件的一个表项2)Listcount属性:控件列表部分项目的个数。3)Mutselect属性:可以设置列表框为单选或允许多选属性.4)Selectd属性:标示一个数组,数组各元素为:5)Selected(0),selected(1)11.滚动条

32、类的控件:1)Value属性:滚动条上滑块所在位置由value值所决定。2)Max和min属性:对value值的最大,最小进行限制。3)Largechange属性:用户点击滚动条与键头之间的区域时,value的改变量。4) OnClick事件:用来添加按钮的单击事件所执行的程序代码。12.定时器类类的控件:1)Interval属性:表示定时的时间间隔,以毫秒为单位。2)Enable属性:为true时(缺省值),激活定时器开始计时;为false时处于休眠状态.Visual basic6.0连接数据库的主要方式以下几种方式:一是:用data控件进行数据库链接 ,二是利用adodc(ADO Data

33、 Control)进行数据库链接 。三是: 利用DataEnvironment进行数据库链接.四是利用ADO(ActiveX Data Objects)进行编程:现在我们来大致对这几种技术应用介绍:一、 用data控件进行数据库链接:第一步:给窗体添加一个Data控件。第二步:用Access建立一个名为Pad的数据库,在库中建立一个表Myset,给表添加四个字段:backcolor(数据),forecolor(文本),fontname(文本),fontsize(文本)。注意:请将库文件存入程序所在目录。 如果你的机器没安装有Access,可通过VB建库。二、 利用adodc(ADO Data

34、Control)进行数据库链接:使用adodata控件访问数据库可以完全不用编写代码,只需要通过简单的设置和操作其属性就可以实现与数据库的连接,通过绑定数据感知控件,就能提供一个访问数据库的界面,用来实现对数据库的浏览,贴加,删除,修改等操作.三、 利用DAO对数据库进行操纵:在visual basic 中提供了两种与jet数据引擎接口的方法:data控件与数据访问对象(DAO)DAO是database object的英文缩写,要访问数据库一方面数据库要提供访问接口,另一方面要在编程环境中有对数据库的支持.DAO模型是设计关系数据库系统结构的对象类的集合.他们提供了管理关系型数据库系统所需要的

35、全部操作属性和方法,这其中包括建立数据库,定义表,字段和建立表间关系,定位和查询数据库等.关系数据库介绍:关系数据库是目前各类数据库中最重要、最流行的数据库,他应用数学方法来处理数据库数据,是目前使用最广泛的数据库系统。20世纪70年代以后开发的数据库管理系统产品几乎都是基于关系的。在数据库发展的历史上,最重要的成就就是关系模型。 关系数据库系统与非关系数据库系统的区别是:关系系统只有“表“这一种数据结构;而非关系数据库系统还有其他数据结构,对这些数据结构有其他的操作。结构化查询语言SQL(Structured Query Language)是一种介于关系代数与关系演算之间的语言,其功能包括查

36、询、操纵、定义和控制四个方面,是一个通用的、功能极强的关系数据库语言。目前已成为关系数据库的标准语言 Microsoft Access介绍:使用 Microsoft Access,可以在单一的数据库文件中管理所有的信息。在这个文件中,用户可以将自己的数据分别保存在各自独立的存储空间中,这些空间称作表;可以使用联机窗体来查看、添加及更新表中的数据;使用查询来查找并检索所要的数据;也可以使用报表以特定的版面布置来分析及打印数据。 如果要保存数据,请为每一种类型的信息创建一个表。如果要从查询、窗体或报表中的多个表中将数据合并在一起,就要定义各个表之间的关系。

37、如果要搜索并检索符合指定条件的数据,包括来自多个表中的数据,就要创建查询。查询的同时也可以更新或删除多条记录,并对数据执行内嵌或自定义的计算。 如果要简单地直接在某个表中查看、输入及更改数据,请创建一个窗体。在打开一个窗体时,Microsoft Access 将从一个或多个表中检索数据,并使用用户在“窗体向导”选择的版面布局或所创建的版面布局,将窗体显示在屏幕上。 如果要分析数据或将数据以特定的方式打印出来,请创建一个报表。例如,可以打印一份将数据分组并计算数据总和的报表,也可以打印另一份带有各种数据格式的打印邮件标签的报表。第2章 系统的分析2.1系统开发的目标和思想本系

38、统开发目标是服务于高速公路收费管理人员,方便工作人员,对过往车辆收费,发放收费票据记录,对信息的分类管理等.同时力求做到界面人性化,功能齐全,数据存储安全.2.2 系统的可行性分析技术上:本系统采用visual basic 6.0与微软的access作为数据库,技术上开发难度一般.经济上:本系统服务于超市管理人员,提高了工作人员办事效率,节省了开支.所以具有经济上的可行性.社会上:本系统同时也方便了广大顾客,.所以具有社会可行性.第3章 系统的设计3.1系统的功能结构设计1系统的结构设计图如下图3-1:程序登陆主界面商品类型管理商品管理报损管理进货管理销售管理供货商管理销售分析帮助退出31 系

39、统的数据库设计1用户登陆图如下图3-2:2购入商品图如下图3-3:3商品保损图如下图3-4:4商品信息图如下图3-5:5供应商图如下图3-6:6销售图如下图3-7:3.3 界面设计与代码设计1. 登陆界面设计图如下图3-8:代码分析:Option ExplicitPrivate Declare Function GetUserName Lib "advapi32.dll" Alias "GetUserNameA" (ByVal lpbuffer As String, nSize As Long) As LongPublic OK As BooleanDi

40、m m_Admin As New clsAdminDim m_nErrCount As IntegerPrivate Sub Form_Load() m_nErrCount = 0End SubPrivate Sub cmdCancel_Click() OK = False Me.HideEnd SubPrivate Sub cmdOK_Click() 'ToDo: 创建测试密码是否正确 '检查正确密码 Dim Account As String Dim Pwd As String Account = RealString(txtUserName.Text) Pwd = Rea

41、lString(txtPassword.Text) '判断密码是否正确 If Not m_Admin.CheckPwd(Account, Pwd) Then m_nErrCount = m_nErrCount + 1 If m_nErrCount >= 3 Then MsgBox "输入密码错误次数太多,请稍后重试", vbExclamation End End If MsgBox "密码错误,再试一次!还有 " & 3 - m_nErrCount & " 次机会,注意密码区分大小写", vbCritic

42、al, "登录" txtPassword.SetFocus txtPassword.SelStart = 0 txtPassword.SelLength = Len(txtPassword.Text) Else OK = True g_Account = Account Me.Hide End IfEnd Sub2:报损信息图如下图3-9:代码分析:Option ExplicitPrivate OK As Boolean '确定用户按了OK还是CANCEL按钮Private m_obj As clsDispose '数据对象,用来存储用户输入数据Public

43、 m_ViewType As gxcViewType '显示状态,指添加还是修改Private m_TypeId As LongPrivate m_Account As String '调用此对话框的操作员'根据是“新增”还是修改,确定显示内容Private Sub SetStatus() '设置控件默认值 Call SetDefaultValue '设置状态 Select Case m_ViewType Case vtadd '添加 CancelButton.Visible = True OKButton.Caption = "确定&

44、quot; Case vtModify '修改 CancelButton.Visible = True OKButton.Caption = "保存" Case vtInfo '查看 CancelButton.Visible = False OKButton.Caption = "关闭" End SelectEnd Sub'打开对话框,并传出用户输入数据Public Function ShowDlg(ByRef obj As Object, _ ByVal eViewType As gxcViewType, _ Optional

45、nTypeId As Long = -1, _ Optional strUser As String = "") As Boolean '保存数据 Set m_obj = obj '用户输入数据存放于此对象中 m_ViewType = eViewType '对话框状态 If nTypeId = -1 And (Not m_obj Is Nothing) Then m_TypeId = m_obj.TypeId Else m_TypeId = nTypeId End If m_Account = strUser '调用此对话框的用户账号 

46、9;根据新增、编辑或查看设置显示内容 SetStatus '显示对话框 OK = False Me.Show vbModal If OK = False Then ShowDlg = False Exit Function End If '保存数据 Set obj = m_obj '返回并释放对话框 ShowDlg = True Unload Me End Function'设置控件默认值Private Sub SetDefaultValue() Dim ctl As Control Dim i As Integer '如果是新增,则清空所有文本框 &#

47、39;此处判断 m_obj为空与判断m_ViewType = vtAdd等效,但更安全 If m_obj Is Nothing Then For Each ctl In Controls If TypeOf ctl Is TextBox Then ctl.Text = "" End If Next Else '用传入对象的值更新数据 With m_obj txtCount.Text = .Count txtReason.Text = .Reason txtRemark.Text = .Remark cboUnit.ListIndex = 0 dtpRegDate.V

48、alue = .RegDate For i = 0 To cboMerchName.ListCount - 1 If cboMerchName.ItemData(i) = .MerchandiseID Then cboMerchName.ListIndex = i '客户类型Id Exit For End If Next i End With End IfEnd Sub'检查输入有效性Private Function CheckValid() As Boolean CheckValid = False If txtCount.Text = "" _ Or t

49、xtReason.Text = "" _ Or txtRemark.Text = "" Then MsgBox "请填写完毕以上各项内容" Exit Function End If If cboMerchName.Text = "" Then MsgBox "请填写完毕以上各项内容" Exit Function End If If Not IsNumeric(txtCount.Text) Then MsgBox "数量请输入数字" Exit Function End If I

50、f Not IsDate(dtpRegDate.Value) Then MsgBox "请输入正确的日期格式" Exit Function End If CheckValid = True End Function'保存数据Private Sub SaveValue() '给“成员变量”对象赋值 With m_obj '注意以下利用RealString函数替换去除输入中的单引号 .Count = txtCount.Text .Reason = RealString(txtReason.Text) .Remark = RealString(txtRem

51、ark.Text) .MerchandiseID = cboMerchName.ItemData(cboMerchName.ListIndex) '商品类型Id .MerchName = cboMerchName.Text .RegDate = dtpRegDate.Value .OperatorId = m_Account '操作者账号 End WithEnd Sub'取消按钮Private Sub CancelButton_Click() Unload MeEnd SubPrivate Sub Form_Load() Dim opMerch As New clsOp

52、Merch opMerch.FillCombo cboMerchNameEnd Sub'确定按钮Private Sub OKButton_Click() OK = True '检测输入有效性 If Not CheckValid Then Exit Sub '如果是新增状态,则初始化一个数据对象 If m_ViewType = vtadd Then Set m_obj = New clsDispose '保存用户输入 SaveValue Me.HideEnd Sub3:供应商信息图如下图3-10:代码分析:Option ExplicitPrivate OK As

53、Boolean '确定用户按了OK还是CANCEL按钮Private m_obj As clsProvider '数据对象,用来存储用户输入数据Public m_ViewType As gxcViewType '显示状态,指添加还是修改'根据是“新增”还是修改,确定显示内容Private Sub SetStatus() '设置控件默认值 Call SetDefaultValue '设置状态 Select Case m_ViewType Case vtadd '添加 CancelButton.Visible = True OKButton.

54、Caption = "确定" Case vtModify '修改 CancelButton.Visible = True OKButton.Caption = "保存" Case vtInfo '查看 CancelButton.Visible = False OKButton.Caption = "关闭" End SelectEnd Sub'打开对话框,并传出用户输入数据Public Function ShowDlg(ByRef obj As Object, _ ByVal eViewType As gxcViewType) As Boolean '保存数据 Set m_obj = obj '用户输入数据存放于此对象中 m_ViewType = eViewType '对话框状态 '根据新增、编辑或查看设置

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论