转超市进销存管理系统的设计方法及思想VB6ACCESS

上传人:痛*** 文档编号:118745389 上传时间:2022-07-12 格式:DOC 页数:43 大小:293KB
收藏 版权申诉 举报 下载
转超市进销存管理系统的设计方法及思想VB6ACCESS_第1页
第1页 / 共43页
转超市进销存管理系统的设计方法及思想VB6ACCESS_第2页
第2页 / 共43页
转超市进销存管理系统的设计方法及思想VB6ACCESS_第3页
第3页 / 共43页
资源描述:

《转超市进销存管理系统的设计方法及思想VB6ACCESS》由会员分享,可在线阅读,更多相关《转超市进销存管理系统的设计方法及思想VB6ACCESS(43页珍藏版)》请在装配图网上搜索。

1、摘 要1Abstract2第一章 引言411 课题背景412 系统简介51. 3 开发软件介绍6第二章 系统的分析821 系统开发的目标和思想922 系统的可行性分析13第三章 系统的设计1831 系统的功能结构设计1832 系统的数据库设计 .1933 界面设计与代码设计23结束语46致谢47参考文献49摘 要随着经济的发展,社会的进步,计算机越来越深入到我们日常的工作学习及生活中,成为我们日常生活中不可缺少的辅助工具。 随着科学技术的不断提高,计算机科学日渐成熟,其强大的功能已为人们深刻认识,它已进入人类社会的各个领域并发挥着越来越重要的作用。它已经深入到日常工作和生活的方方面面,比如文字

2、处理、信息管理、辅助设计、图形图像处理、教育培训以及游戏娱乐等。各行各业的人们无须经过特别的训练就能够使用电脑完成许许多多复杂的工作。然而,虽然现在世界上已经充满了多如牛毛的各种软件,但它们依然不能满足用户的各种特殊需要,人们还不得不开发适合自己特殊需求的软件。以前开发Windows应用软件是专业人员的工作,需要掌握许多专业知识和经过特殊的培训才能胜任。现在不同了,即使你没有接受过严格的程序设计训练,使用Visual Basic也一样能够开发出功能强大、适合自己特殊需求的应用程序了。Visual Basic继承了Basic语言易学易用的特点,特别适合于初学者学习Windows系统编程。 超市进

3、销存管理系统用计算机管理超市库存进出管理的一种计算机应用技术的创新,在计算机还未普及之前库存管理都是由工作人员手工书写的方式来操作的.现在一般的超市都采用计算机智能化管理,采用计算机作为工具的实用的计算机超市库存管理程序来帮助管理员进行更有效的超市库存管理工作。超市进销存管理系统是典型的信息管理系统(MIS),其开发主要包括后台数据库的建立和维护以及前端应用程序的开发两个方面。对于前者要求建立起数据一致性和完整性强、数据安全性好的库。而对于后者则要求应用程序功能完备,易使用等特点。 经过分析,我们使用 MICROSOFT公司的 VISUAL BASIC开发工具,利用其提供的各种面向对象的开发工

4、具,尤其是数据窗口这一能方便而简洁操纵数据库的智能化对象,首先在短时间内建立系统应用原型,然后,对初始原型系统进行需求迭代,不断修正和改进,直到形成用户满意的可行系统。因为本人能力有限,加上时间紧迫,所以设计出来的本系统可能功能比较简单,另外本系统是单机版,不能实现网络互联操作,这些都有待于我在以后的工作学习中进一步改进。关键字:超市进销存管理,MIS,visual basic ,数据库第一章 引言11 课题背景超市进销存管理系统用计算机管理超市库存进出管理的一种计算机应用技术的创新,在计算机还未普及之前库存管理都是由工作人员手工书写的方式来操作的.现在一般的超市都采用计算机智能化管理,采用计

5、算机作为工具的实用的计算机超市库存管理程序来帮助管理员进行更有效的超市库存管理工作。超市进销存管理系统是典型的信息管理系统(MIS),其开发主要包括后台数据库的建立和维护以及前端应用程序的开发两个方面。对于前者要求建立起数据一致性和完整性强、数据安全性好的库。而对于后者则要求应用程序功能完备,易使用等特点。12 系统简介 本系统采用visual basic与Access作为数据库的方式编写,主要服务于超市库存管理人员的日常工作.主要由以下几大功能模块构成:一. 商品类型管理:添加商品类型,修改商品类型,删除商品类型二. 商品管理:添加商品信息,修改商品信息,删除商品信息三. 进货管理:添加进货

6、管理,修改进货管理,删除进货管理四. 销售管理: 添加销售管理,修改销售管理,删除销售管理五. 报损管理: 添加报损管理,修改报损管理,删除报损管理1. 3 开发软件介绍Visual Basic 6.0是Micrsoft公司出品的开发工具,Visual Basic是一种可视化的,面向对象的Windows开发语言,它具有易用,通用和开发效率高的特点。随着微软对它不断地改进以及计算机本身性能的提高,使得Visual Basic越来越适合一般的应用程序开发。正如Bill Gate所说,世界上绝大多数的Windows应用程序是用Visual Basic编写的。在众多的开发工具中,我们为什么要选择Vis

7、ual Basic6.0呢?因为VB具有众多其它开发工具所没有的优点!具体介绍如下:u 开发的高效u 语言的高效u 编译的高效u 执行的高效u 维护的高效基于以上理由,我们毫不忧郁的选择了VB6.0做为我们的开发工具!主要的控件及其基本属性,事件简介u 命令按钮类的控件:1) Caption属性:用来显示在控件上的标题。2) Enable属性:控制控件的激活状态灰色或可用。3) Appearance属性:值为1时,则以3D效果显示该控件,0则不然。4) Backcolor属性:用来改变在按钮上显示图像的背景色。5) Cancel属性:该属性决定按钮是否为一个”取消”按钮。6) Default属

8、性:决定哪一个命令按钮控件是窗体的缺省命令按钮.7) Font属性:控制各种文字字体类型.8) Left,top,height,width属性:设定控件的位置与大小.9) Style,picture属性:决定按钮的显示方式是否为图像形式出现.10) Visible属性:确定控件运行时是否为可见.11) Index属性:当控件为一控件数组时,此属性值为该控件在数组的下标值.12) DownPicture属性:设置/返回一个对图片的引用,该图片在按钮被单击处于压下状态时显示。13) DisabledPicture属性:设置/返回一个对图片的引用,该图片在控件无效时显示在控件中。14) MaskCo

9、lor属性:设置/返回一个在按钮的图片中作为“掩码“的的颜色15) Picture属性:设置返回commandButton控件中要显示的图片。u 命令按钮类的事件:1) 单击事件Click事件(1) 触发与适用此事件是在一个命令按钮对象上按下然后释放一个鼠标按钮时发生。命令按钮的Click事件仅对当单击鼠标时发生。(2) 事件处理过程按钮单击事件的处理过程为: Private Sub object-Click(Index As Integer)其中Object为引发该事件的对象名称。如果是命令按钮的控件是数组,则需要使用Index参数标识该控件。2) 获得焦点GotFocus事件(1) 触发与

10、适用 当命令按钮获得焦点产生该事件,获得焦点可以通过诸如Tab切换或单击对象之类的用户动作,或在代码中用SetFocus方法改变焦点来实现。(2) 事件处理过程命令按钮GotFoucs事件处理过程为:Private Sub Object-GotFocus(Index As Integer)3) LostFocus事件:当一个对象失去焦点时发生4) KeyDown事件:当命令按钮具有焦点时按下一个键时发生5) KeyUp事件:当命令按钮具有焦点时释放一个键时发生。6) KeyPress事件:当用户按下或松开一个ANSI键时发生。7) MouseDown事件:当在命令按钮上按下鼠标按钮时发生。8)

11、 MouseMove事件:当命令按钮上移动鼠标时发生。9) MouseUp事件:当在命令按钮上释放鼠标按钮时发生。 u 标签框类的控件类的控件:1) Caption属性:在应用程序界面上加入说明。2) Autosize属性:决定控件是否自动改变大小以显示其全部内容。3) Backstyle属性:用以指示标签是否透明.4) Bordstyle属性:用以设定控件是否有边框。u 文本框类的控件:1) Text属性:通过像text属性赋值的方法来改变该属性的值。2) Maxlength属性:该属性设定在文本框控件中能够输入的最大字符数。3) Multline属性:该属性设定text字符串中是否接受换行

12、符。4) Scrollbars属性:该属性决定是否为文本框加滚动条。5) Passwordchar属性:该属性设定输入文本的特殊显示字符,在设计密码程序时非常有用。6) Change事件属性:文本框的内容发生改变时,相应的控件之间发生相应的改变,具有即时性。7) Keypress:事件由用户在文本框控件中按任意键触发。8) Alignment属性:设定控件中的文本对其方式9) Appearance属性:设定一个对象在运行时是否可以3D效果显示。10) BackColor属性:设置返回背景色11) BorderStyle属性:设置对象的边框样式12) DataField属性:设定数据使用者将被绑

13、定到的字段名13) DataFormat属性:设定DataFormat对象,用于数据绑定14) DataMember属性:从数据供应程序提供的几个数据成员中返回/设定一个特定的数据成员15) DataSource属性:设定控件绑定的一个数据源16) DragIcon属性:设定图标,它将在拖放操作中作为指针显示17) DragMode模式:设定一个值,确定在拖放操作中所用方式18) Enabled属性:设置/返回运行时TextBox是否相应用户事件19) Font属性:设置/返回字体属性20) ForeColor属性:设置/返回文本的前景色21) Height属性:设置/返回TextBox的高度

14、22) IMEMode属性:设置/返回数值用来确定输入方法编辑器的状态23) Index属性:设置/返回唯一的标识控件数组中该控件的编号24) Left属性:设置/返回TextBox控件的水平位置25) Locked属性:设置/返回TextBox中文本是否可编辑26) LinkItem属性:设置/返回DDE与另一个应用程序会话时,传给接受端的数据27) MaxLength属性:设置/返回一个值,指定在TextBox控件中能够输入的字符最大值28) MouseIcon属性:设置/返回自定义鼠标的图标29) Top属性:设置/返回TextBox控件的垂直位置30) Tag属性:存储过程所需的附加数

15、据u 文本框类的事件:1) Change事件:当改变文本框内容时发生2) Click事件:鼠标单击控件时发生3) DblClick事件:用鼠标左键双击控件时发生4) DragDrop事件:在一个完整的拖放动作完成或使用Drag方法,并将其Action参数设置为2时发生5) DragOver事件:在拖放操作正在进行时发生6) GotFocus事件:当一个命令按钮获得焦点时发生7) LinkClose事件:当一个DDE对话结束时发生8) LinkError事件:当一个DDE对话框过程中出现错误时,该事件发生9) KeyDown事件:当命令按钮具有焦点时按下一个键时发生10) Validate事件:

16、在焦点转换到另一个控件之前发生,此时该控件的Causes Validation 属性值设置为True u 单选按钮类的控件:1) Caption属性:显示在控件上的文本,是单选按钮的标题。2) Alignment属性:决定单选按钮的标题在控件上的位置。3) Enable属性:该控件为灰色时为false,表示运行时不可用。4) Index属性:属性值表示为单选按钮组成的控件中某个按钮的索引值。5) Tabindex属性:建立控件时,vb自动为其分配一个tabindex值,利用tab键可以在控件之间切换焦点。6) Value属性:反映控件状态的属性,返回true表示已选择了该按钮。7) Appea

17、rance 属性:设置/返回一个对象在运行时是否以3D效果显示。8) BackColor 属性:设置/返回背景色。9) Container 属性:设置/返回Form上的控件属性。10) DataField 属性:设置/返回数据使用者将被绑定到的字段名。11) DataFormat 属性:设置/返回DataFormat对象,一个绑定对象将附加到它。12) DisabledPicture 属性:设置/返回一个对图像的引用,该图片在控件无效时显示在控件中。13) DownPicture 属性:设置/返回一个对图片的引用,该图片在控件单击下处于压下状态时显示。14) DragMode 属性:设置/返回

18、一个值,确定在拖放操作中所用的方式。15) Font 属性:设置/返回字体属性。16) FontBold 属性:设置/返回字体粗体样式。17) FontItalic 属性:设置/返回字体斜体样式。 18) FontStrikethru 属性:设置/返回字体删除线样式。19) FontUnderLine 属性:设置/返回字体下划线样式。20) FontName 属性:设置/返回控件中显示文本所用的字体大小。21) FontSize 属性:设置/返回控件中显示文本所用的字体大小22) Height 属性:设置/返回控件的高度。23) MaskColor 属性:设置/返回一个在控件的图片中作为掩码的

19、颜色。24) MousePointer 属性:设置/返回一个值,该值指示在运行时当鼠标移动到对象上时显示的指针类型。u 单选按钮类的常用事件:1) Click 事件:鼠标单击控件时发生。2) DbClick事件: 当在一个对象上按下和释放鼠标按钮并再次按下和释放按钮时,该事件发生。3) DragDrop事件:在一个完整的拖放动作或使用Drag方法,并将其Action参数设置位2时,该事件发生。4) DragOver事件: 在拖放操作正在进行时发生。5) GotFocus事件: 当获的对象焦点时发生。6) LostFocus事件:当对象失去焦点时发生。7) KeyDown事件:当控件具有焦点时按

20、下一个键时发生。8) KeyUp事件: 当控件具有焦点时释放一个键时发生。9) KeyPress事件:当用户按下或释放ANSI一个键时发生。10) MouseDown事件:当在控件上按下鼠标键时发生。11) MouseMove事件:在控件上移动鼠标时发生。12) MouseUp事件:在控件上释放鼠标时发生。u 复选按钮类的控件:1) Caption属性:缺省为check1。2) Index属性:该属性值为复选框控件数组的下标.3) Value属性:value为0表空白,为1表勾号,为2表示灰色勾号.4) Container属性:Form控件上的容器。5) DataChangeed属性:设置/返

21、回一个值,指出被绑定的控件中的数据已经被某进程修改。6) DataField属性:设置或返回数据使用者将被绑定到的字段名。7) DataFormat 属性:设置或返回DataFormat对象,用于数据绑定。8) Datasource属性:设置或返回控件绑定的一个数据源。9) DisabledPicture属性:设置或返回一个对图片的引用,该图片在控件无效时显示在控件中。10) DownPicture 属性:设置或返回一个对图片的引用,该图片在控件被单击处于压下状态时显示。11) DragIcon属性:设置或返回图标,它将在拖放操作中做为指针显示。12) DragMode属性:设置返回一个值,确

22、定在拖放操作中所用方式。13) Font属性:设置或返回字体的属性。14) Name属性:设置或返回控件的标识名。15) Value属性:设置或返回控件的状态。u 复选按钮类的控件的基本事件:1) Click事件:鼠标单击控件时发生。2) DragDrop事件:在一个完整的拖放动作完成或使用Drag方法,并将其Action参数设置为2时发生。3) DragOver事件:在拖放操作正在进行时发生。4) GotFocus事件:在对象获的焦点时发生。,5) OLECompleteDrag事件:当源部件被放到目标时发生,并通知源部件拖放操作被执行或取消。6) OLEDragDrag事件:当源部件决定放

23、操作能发生,却源部件被放到目标部件时,此事件发生。u 框架类的控件:1) List属性:列表框控件的表项是使用数组的方式保存,数组的每一个元素存储列表控件的一个表项1) Listcount属性:控件列表部分项目的个数。2) Mutselect属性:可以设置列表框为单选或允许多选属性.3) Selectd属性:标示一个数组,数组各元素为:4) Selected(0),selected(1)u 滚动条类的控件:1) Value属性:滚动条上滑块所在位置由value值所决定。2) Max和min属性:对value值的最大,最小进行限制。3) Largechange属性:用户点击滚动条与键头之间的区域

24、时,value的改变量。4) OnClick事件:用来添加按钮的单击事件所执行的程序代码。u 定时器类类的控件:1) Interval属性:表示定时的时间间隔,以毫秒为单位。2) Enable属性:为true时(缺省值),激活定时器开始计时;为false时处于休眠状态.Visual basic6.0连接数据库的主要方式以下几种方式:一是:用data控件进行数据库链接 ,二是利用adodc(ADO Data Control)进行数据库链接 。三是: 利用DataEnvironment进行数据库链接.四是利用ADO(ActiveX Data Objects)进行编程:现在我们来大致对这几种技术应用

25、介绍:一、 用data控件进行数据库链接.第一步:给窗体添加一个Data控件。第二步:用Access建立一个名为Pad的数据库,在库中建立一个表Myset,给表添加四个字段:backcolor(数据),forecolor(文本),fontname(文本),fontsize(文本)。注意:请将库文件存入程序所在目录。 如果你的机器没安装有Access,可通过VB建库。二、 利用adodc(ADO Data Control)进行数据库链接:使用adodata控件访问数据库可以完全不用编写代码,只需要通过简单的设置和操作其属性就可以实现与数据库的连接,通过绑定数据感知控件,就能提供一个访问数据库的界

26、面,用来实现对数据库的浏览,贴加,删除,修改等操作.三、 利用DAO对数据库进行操纵:在visual basic 中提供了两种与jet数据引擎接口的方法:data控件与数据访问对象(DAO)DAO是database object的英文缩写,要访问数据库一方面数据库要提供访问接口,另一方面要在编程环境中有对数据库的支持.DAO模型是设计关系数据库系统结构的对象类的集合.他们提供了管理关系型数据库系统所需要的全部操作属性和方法,这其中包括建立数据库,定义表,字段和建立表间关系,定位和查询数据库等.关系数据库介绍:关系数据库是目前各类数据库中最重要、最流行的数据库,他应用数学方法来处理数据库数据,是

27、目前使用最广泛的数据库系统。20世纪70年代以后开发的数据库管理系统产品几乎都是基于关系的。在数据库发展的历史上,最重要的成就就是关系模型。 关系数据库系统与非关系数据库系统的区别是:关系系统只有“表“这一种数据结构;而非关系数据库系统还有其他数据结构,对这些数据结构有其他的操作。结构化查询语言SQL(Structured Query Language)是一种介于关系代数与关系演算之间的语言,其功能包括查询、操纵、定义和控制四个方面,是一个通用的、功能极强的关系数据库语言。目前已成为关系数据库的标准语言MicrosoftAccess介绍:使用MicrosoftAccess,可以在单一的数据库文

28、件中管理所有的信息。在这个文件中,用户可以将自己的数据分别保存在各自独立的存储空间中,这些空间称作表;可以使用联机窗体来查看、添加及更新表中的数据;使用查询来查找并检索所要的数据;也可以使用报表以特定的版面布置来分析及打印数据。 如果要保存数据,请为每一种类型的信息创建一个表。如果要从查询、窗体或报表中的多个表中将数据合并在一起,就要定义各个表之间的关系。 如果要搜索并检索符合指定条件的数据,包括来自多个表中的数据,就要创建查询。查询的同时也可以更新或删除多条记录,并对数据执行内嵌或自定义的计算。 如果要简单地直接在某个表中查看、输入及更改数据,请创建一个窗体。在打开一个窗体时,Microso

29、ftAccess将从一个或多个表中检索数据,并使用用户在“窗体向导”选择的版面布局或所创建的版面布局,将窗体显示在屏幕上。 如果要分析数据或将数据以特定的方式打印出来,请创建一个报表。例如,可以打印一份将数据分组并计算数据总和的报表,也可以打印另一份带有各种数据格式的打印邮件标签的报表。第 二 章 系统的分析21 系统开发的目标和思想本系统开发目标是服务于高速公路收费管理人员,方便工作人员,对过往车辆收费,发放收费票据记录,对信息的分类管理等.同时力求做到界面人性化,功能齐全,数据存储安全.2.2 系统的可行性分析技术上:本系统采用visual basic 6.0与微软的access作为数据库

30、,技术上开发难度一般.经济上:本系统服务于超市管理人员,提高了工作人员办事效率,节省了开支.所以具有经济上的可行性.社会上:本系统同时也方便了广大顾客,.所以具有社会可行性.第 三 章 系统的设计31 系统的功能结构设计程序登陆主界面商品类型管理商品管理报损管理进货管理销售管理供货商管理销售分析帮助退出32 系统的数据库设计1:用户登陆表:2:购入商品表:3:商品保损表:4:商品信息表:5:供应商表:6:销售表:3.3 界面设计与代码设计1. 登陆界面设计:代码分析:Option ExplicitPrivate Declare Function GetUserName Lib advapi32

31、.dll Alias GetUserNameA (ByVal lpbuffer As String, nSize As Long) As LongPublic OK As BooleanDim 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

32、 Account As String Dim Pwd As String Account = RealString(txtUserName.Text) Pwd = RealString(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_nErrC

33、ount & 次机会,注意密码区分大小写, vbCritical, 登录 txtPassword.SetFocus txtPassword.SelStart = 0 txtPassword.SelLength = Len(txtPassword.Text) Else OK = True g_Account = Account Me.Hide End If End Sub2:报损信息表:代码分析:Option ExplicitPrivate OK As Boolean 确定用户按了OK还是CANCEL按钮Private m_obj As clsDispose 数据对象,用来存储用户输入数据Pub

34、lic 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 = 确定 Case vtModify 修改 CancelButton.Vis

35、ible = 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 nTypeId As Long = -1, _ Optional strUser As String = ) As Boolean 保存数据 Set m_o

36、bj = 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 调用此对话框的用户账号 根据新增、编辑或查看设置显示内容 SetStatus 显示对话框 OK = False Me.Show vbModal If OK = False Then ShowDlg = False Exit Function End

37、If 保存数据 Set obj = m_obj 返回并释放对话框 ShowDlg = True Unload Me End Function设置控件默认值Private Sub SetDefaultValue() Dim ctl As Control Dim i As Integer 如果是新增,则清空所有文本框 此处判断 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 Nex

38、t Else 用传入对象的值更新数据 With m_obj txtCount.Text = .Count txtReason.Text = .Reason txtRemark.Text = .Remark cboUnit.ListIndex = 0 dtpRegDate.Value = .RegDate For i = 0 To cboMerchName.ListCount - 1 If cboMerchName.ItemData(i) = .MerchandiseID Then cboMerchName.ListIndex = i 客户类型Id Exit For End If Next i

39、End With End If End Sub检查输入有效性Private Function CheckValid() As Boolean CheckValid = False If txtCount.Text = _ Or txtReason.Text = _ Or txtRemark.Text = Then MsgBox 请填写完毕以上各项内容 Exit Function End If If cboMerchName.Text = Then MsgBox 请填写完毕以上各项内容 Exit Function End If If Not IsNumeric(txtCount.Text) Th

40、en MsgBox 数量请输入数字 Exit Function End If If 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 = Real

41、String(txtRemark.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 clsOpMe

42、rch 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.Hide End Sub3:供应商表:代码分析:Option ExplicitPrivate OK As Boolean 确定用户按了OK还是CANCEL按钮Priv

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

44、n.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 对话框状态 根据新增、编辑或查看设置显示内容 SetStatus 显示对话框

45、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 如果是新增,则清空所有文本框 此处判断 m_obj为空与判断m_ViewType = vtAdd等效,但更安全 If m_obj Is Nothing T

46、hen For Each ctl In Controls If TypeOf ctl Is TextBox Then ctl.Text = End If Next Else 用传入对象的值更新数据 With m_obj txtName.Text = .ProviderName txtIntro.Text = .Introduce txtRemark.Text = .Remark End With End If End Sub检查输入有效性Private Function CheckValid() As Boolean If txtName.Text = _ Or txtIntro.Text =

47、 _ Or txtRemark.Text = Then MsgBox 请填写完毕以上各项内容 CheckValid = False Exit Function End If CheckValid = True End Function保存数据Private Sub SaveValue() 给“成员变量”对象赋值 With m_obj 注意以下利用RealString函数替换去除输入中的单引号 .ProviderName = RealString(txtName.Text) .Introduce = RealString(txtIntro.Text) .Remark = RealString(t

48、xtRemark.Text) End WithEnd Sub取消按钮Private Sub CancelButton_Click() Unload MeEnd Sub确定按钮Private Sub OKButton_Click() OK = True 检测输入有效性 If Not CheckValid Then Exit Sub 如果是新增状态,则初始化一个数据对象 If m_ViewType = vtadd Then Set m_obj = New clsProvider 保存用户输入 SaveValue Me.Hide End Sub5:管理员列表:代码分析:Option Explicit

49、Dim opAdmin As New clsOpAdminPrivate Sub CancelButton_Click() Unload MeEnd SubPrivate Sub cmdAdd_Click() opAdmin.Add lvAdminEnd SubPrivate Sub cmdDel_Click() opAdmin.Delete lvAdminEnd SubPrivate Sub cmdModify_Click() opAdmin.Modify lvAdminEnd SubPrivate Sub Form_Load() opAdmin.FillListView lvAdminEn

50、d Sub6:主界面设计:代码分析:Option ExplicitConst NAME_COLUMN = 0Const TYPE_COLUMN = 1Const SIZE_COLUMN = 2Const DATE_COLUMN = 3 Dim mbMoving As BooleanConst sglSplitLimit = 500Private Sub Form_Load() LoadResStrings Me Me.Left = GetSetting(App.Title, Settings, MainLeft, 1000) Me.Top = GetSetting(App.Title, Set

51、tings, MainTop, 1000) Me.Width = GetSetting(App.Title, Settings, MainWidth, 6500) Me.Height = GetSetting(App.Title, Settings, MainHeight, 6500) lvMerch.View = Val(GetSetting(App.Title, Settings, ViewMode, 0) 初始化数据 Call InitMainEnd SubPrivate Sub Form_Unload(Cancel As Integer) Dim i As Integer close

52、all sub forms For i = Forms.Count - 1 To 1 Step -1 Unload Forms(i) Next If Me.WindowState vbMinimized Then SaveSetting App.Title, Settings, MainLeft, Me.Left SaveSetting App.Title, Settings, MainTop, Me.Top SaveSetting App.Title, Settings, MainWidth, Me.Width SaveSetting App.Title, Settings, MainHei

53、ght, Me.Height End If SaveSetting App.Title, Settings, ViewMode, lvMerch.ViewEnd SubPrivate Sub Form_Resize() On Error Resume Next If Me.Width 3000 Then Me.Width = 3000 SizeControls imgSplitter.LeftEnd SubPrivate Sub imgSplitter_MouseDown(Button As Integer, Shift As Integer, x As Single, y As Single

54、) With imgSplitter picSplitter.Move .Left, .Top, .Width 2, .Height - 20 End With picSplitter.Visible = True mbMoving = TrueEnd SubPrivate Sub imgSplitter_MouseMove(Button As Integer, Shift As Integer, x As Single, y As Single) Dim sglPos As Single If mbMoving Then sglPos = x + imgSplitter.Left If sg

55、lPos Me.Width - sglSplitLimit Then picSplitter.Left = Me.Width - sglSplitLimit Else picSplitter.Left = sglPos End If End IfEnd SubPrivate Sub imgSplitter_MouseUp(Button As Integer, Shift As Integer, x As Single, y As Single) SizeControls picSplitter.Left picSplitter.Visible = False mbMoving = FalseEnd SubPrivate Sub TreeView1_DragDrop(Source As Control, x As Single, y As Single) If Source = imgSplitter Then SizeControls x End IfEnd SubSub SizeControls(x As Single) On Error Resume Next 设置 Width 属性 If x (Me.Width - 1500) Then x = Me.Width - 1500 tvTreeView.Width = x imgSplitter.Left = x ss

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

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!