vb与EXCEL的连接

一、 VB读写EXCEL表:

VB本身提自动化功能可以读写EXCEL表,其方法如下:

1、在工程中引用Microsoft Excel类型库:

"工程"菜单中选择"引用"栏;选择Microsoft Excel 9.0 Object LibraryEXCEL2000),然后选择"确定"。表示在工程中要引用EXCEL类型库。

2、在通用对象的声明过程中定义EXCEL对象:

Dim xlApp As Excel.Application

Dim xlBook As Excel.WorkBook

Dim xlSheet As Excel.Worksheet

3、在程序中操作EXCEL表常用命令:

Set xlApp = CreateObject("Excel.Application") '创建EXCEL对象

Set xlBook = xlApp.Workbooks.Open("文件名") '打开已经存在的EXCEL工件簿文件

xlApp.Visible = True '设置EXCEL对象可见(或不可见)

Set xlSheet = xlBook.Worksheets("表名") '设置活动工作表

xlSheet.Cells(row, col) = '给单元格(row,col)赋值

xlSheet.PrintOut '打印工作表

xlBook.Close (True) '关闭工作簿

xlApp.Quit '结束EXCEL对象

Set xlApp = Nothing '释放xlApp对象

xlBook.RunAutoMacros (xlAutoOpen) '运行EXCEL启动宏

xlBook.RunAutoMacros (xlAutoClose) '运行EXCEL关闭宏

4、在运用以上VB命令操作EXCEL表时,除非设置EXCEL对象不可见,否则VB程序可继续执行其它操作,也能够关闭EXCEL,同时也可对EXCEL进行操作。但在EXCEL操作过程中关闭EXCEL对象时,VB程序无法知道,如果此时使用EXCEL对象,则VB程序会产生自动化错误。形成VB程序无法完全控制EXCEL的状况,使得VBEXCEL脱节。

二、 EXCEL的宏功能:

EXCEL提供一个Visual Basic编辑器,打开Visual Basic编辑器,其中有一工程属性窗口,点击右键菜单的"插入模块",则增加一个"模块1",在此模块中可以运用Visual Basic语言编写函数和过程并称之为宏。其中,EXCEL有两个自动宏:一个是启动宏(Sub Auto_Open()),另一个是关闭宏(Sub Auto_Close())。它们的特性是:当用EXCEL打含有启动宏的工簿时,就会自动运行启动宏,同理,当关闭含有关闭宏的工作簿时就会自动运行关闭宏。但是通过VB的自动化功能来调用EXCEL工作表时,启动宏和关闭宏不会自动运行,而需要在VB中通过命令xlBook.RunAutoMacros (xlAutoOpen)xlBook.RunAutoMacros (xlAutoClose) 来运行启动宏和关闭宏。

三、 VBEXCEL的相互勾通:

充分利用EXCEL的启动宏和关闭宏,可以实现VBEXCEL的相互勾通,其方法如下:

EXCEL的启动宏中加入一段程序,其功能是在磁盘中写入一个标志文件,同时在关闭宏中加入一段删除此标志文件的程序。VB程序在执行时通过判断此标志文件存在与否来判断EXCEL是否打开,如果此标志文件存在,表明EXCEL对象正在运行,应该禁止其它程序的运行。如果此标志文件不存在,表明EXCEL对象已被用户关闭,此时如果要使用EXCEL对象运行,必须重新创建EXCEL对象。

四、举例:

1、在VB中,建立一个FORM,在其上放置两个命令按钮,将Command1Caption属性改为EXCELCommand2Caption属性改为End。然后在其中输入如下程序:

Dim xlApp As Excel.Application '定义EXCEL

Dim xlBook As Excel.Workbook '定义工件簿类

Dim xlsheet As Excel.Worksheet '定义工作表类

Private Sub Command1_Click() '打开EXCEL过程

If Dir("D:\temp\excel.bz") = "" Then '判断EXCEL是否打开

Set xlApp = CreateObject("Excel.Application") '创建EXCEL应用类

xlApp.Visible = True '设置EXCEL可见

Set xlBook = xlApp.Workbooks.Open("D:\temp\bb.xls") '打开EXCEL工作簿

Set xlsheet = xlBook.Worksheets(1) '打开EXCEL工作表

xlsheet.Activate '激活工作表

xlsheet.Cells(1, 1) = "abc" '给单元格1行驶列赋值

xlBook.RunAutoMacros (xlAutoOpen) 运行EXCEL中的启动宏

Else

MsgBox ("EXCEL已打开")

End If

End Sub

Private Sub Command2_Click()

If Dir("D:\temp\excel.bz") <> "" Then 'VB关闭EXCEL

xlBook.RunAutoMacros (xlAutoClose) '执行EXCEL关闭宏

xlBook.Close (True) '关闭EXCEL工作簿

xlApp.Quit '关闭EXCEL

End If

Set xlApp = Nothing '释放EXCEL对象

End

End Sub

2、在D盘根目录上建立一个名为Temp的子目录,在Temp目录下建立一个名为"bb.xls"EXCEL文件。

3、在"bb.xls"中打开Visual Basic编辑器,在工程窗口中点鼠标键选择插入模块,在模块中输入入下程序存盘:

Sub auto_open()

Open "d:\temp\excel.bz" For Output As #1 '写标志文件

Close #1

End Sub

Sub auto_close()

Kill "d:\temp\excel.bz" '删除标志文件

End Sub

4、运行VB程序,点击EXCEL按钮可以打开EXCEL系统,打开EXCEL系统后,VB程序和EXCEL分别属两个不同的应用系统,均可同时进行操作,由于系统加了判断,因此在VB程序中重复点击EXCEL按钮时会提示EXCEL已打开。如果在EXCEL中关闭EXCEL后再点EXCEL按钮,则会重新打开EXCEL。而无论EXCEL打开与否,通过VB程序均可关闭EXCEL。这样就实现了VBEXCEL的无缝连接。

用法:CFileDialog filedi;//定义一个文件夹对话框实例
filedi.Domadal()// 弹出对话框
 
  
WM_NULL = $0000; 
WM_CREATE = $0001; 应用程序创建一个窗口 
WM_DESTROY = $0002; 一个窗口被销毁 
WM_MOVE = $0003; 移动一个窗口 
WM_SIZE = $0005; 改变一个窗口的大小 
WM_ACTIVATE = $0006; 一个窗口被激活或失去激活状态; 
WM_SETFOCUS = $0007; 获得焦点后 
WM_KILLFOCUS = $0008; 失去焦点 
WM_ENABLE = $000A; 改变enable状态 
WM_SETREDRAW = $000B; 设置窗口是否能重画 
WM_SETTEXT = $000C; 应用程序发送此消息来设置一个窗口的文本 
WM_GETTEXT = $000D; 应用程序发送此消息来复制对应窗口的文本到缓冲区 
WM_GETTEXTLENGTH = $000E; 得到与一个窗口有关的文本的长度(不包含空字符) 
WM_PAINT = $000F; 要求一个窗口重画自己 
WM_CLOSE = $0010; 当一个窗口或应用程序要关闭时发送一个信号 
WM_QUERYENDSESSION = $0011; 当用户选择结束对话框或程序自己调用ExitWindows函数 
WM_QUIT = $0012; 用来结束程序运行或当程序调用postquitmessage函数 
WM_QUERYOPEN = $0013; 当用户窗口恢复以前的大小位置时,把此消息发送给某个图标 
WM_ERASEBKGND = $0014; 当窗口背景必须被擦除时(例在窗口改变大小时) 
WM_SYSCOLORCHANGE = $0015; 当系统颜色改变时,发送此消息给所有顶级窗口 
WM_ENDSESSION = $0016; 当系统进程发出WM_QUERYENDSESSION消息后,此消息发送给应用程序,通知它对话是否结束 
WM_SYSTEMERROR = $0017; 
WM_SHOWWINDOW = $0018; 当隐藏或显示窗口是发送此消息给这个窗口 
WM_ACTIVATEAPP = $001C; 发此消息给应用程序哪个窗口是激活的,哪个是非激活的; 
WM_FONTCHANGE = $001D; 当系统的字体资源库变化时发送此消息给所有顶级窗口 
WM_TIMECHANGE = $001E; 当系统的时间变化时发送此消息给所有顶级窗口 
WM_CANCELMODE = $001F; 发送此消息来取消某种正在进行的摸态(操作) 
WM_SETCURSOR = $0020; 如果鼠标引起光标在某个窗口中移动且鼠标输入没有被捕获时,就发消息给某个窗口 
WM_MOUSEACTIVATE = $0021; 当光标在某个非激活的窗口中而用户正按着鼠标的某个键发送此消息给当前窗口 
WM_CHILDACTIVATE = $0022; 发送此消息给MDI子窗口当用户点击此窗口的标题栏,或当窗口被激活,移动,改变大小 
WM_QUEUESYNC = $0023; 此消息由基于计算机的训练程序发送,通过WH_JOURNALPALYBACKhook程序分离出用户输入消息 
WM_GETMINMAXINFO = $0024; 此消息发送给窗口当它将要改变大小或位置; 
WM_PAINTICON = $0026; 发送给最小化窗口当它图标将要被重画 
WM_ICONERASEBKGND = $0027; 此消息发送给某个最小化窗口,仅当它在画图标前它的背景必须被重画 
WM_NEXTDLGCTL = $0028; 发送此消息给一个对话框程序去更改焦点位置 
WM_SPOOLERSTATUS = $002A; 每当打印管理列队增加或减少一条作业时发出此消息 
WM_DRAWITEM = $002B; buttoncomboboxlistboxmenu的可视外观改变时发送此消息给这些空件的所有者 
WM_MEASUREITEM = $002C; button, combo box, list box, list view control, or menu item 被创建时发送此消息给控件的所有者 
WM_DELETEITEM = $002D; the list box  combo box 被销毁   某些项被删除通过LB_DELETESTRING, LB_RESETCONTENT, CB_DELETESTRING, or CB_RESETCONTENT 消息 
WM_VKEYTOITEM = $002E; 此消息有一个LBS_WANTKEYBOARDINPUT风格的发出给它的所有者来响应WM_KEYDOWN消息 
WM_CHARTOITEM = $002F; 此消息由一个LBS_WANTKEYBOARDINPUT风格的列表框发送给他的所有者来响应WM_CHAR消息 
WM_SETFONT = $0030; 当绘制文本时程序发送此消息得到控件要用的颜色 
WM_GETFONT = $0031; 应用程序发送此消息得到当前控件绘制文本的字体 
WM_SETHOTKEY = $0032; 应用程序发送此消息让一个窗口与一个热键相关连 
WM_GETHOTKEY = $0033; 应用程序发送此消息来判断热键与某个窗口是否有关联 
WM_QUERYDRAGICON = $0037; 此消息发送给最小化窗口,当此窗口将要被拖放而它的类中没有定义图标,应用程序能返回一个图标或光标的句柄,当用户拖放图标时系统显示这个图标或光标 
WM_COMPAREITEM = $0039; 发送此消息来判定comboboxlistbox新增加的项的相对位置 
WM_GETOBJECT = $003D; 
WM_COMPACTING = $0041; 显示内存已经很少了 
WM_WINDOWPOSCHANGING = $0046; 发送此消息给那个窗口的大小和位置将要被改变时,来调用setwindowpos函数或其它窗口管理函数 
WM_WINDOWPOSCHANGED = $0047; 发送此消息给那个窗口的大小和位置已经被改变时,来调用setwindowpos函数或其它窗口管理函数 
WM_POWER = $0048;(适用于16位的windows)当系统将要进入暂停状态时发送此消息 
WM_COPYDATA = $004A; 当一个应用程序传递数据给另一个应用程序时发送此消息 
WM_CANCELJOURNAL = $004B; 当某个用户取消程序日志激活状态,提交此消息给程序 
WM_NOTIFY = $004E; 当某个控件的某个事件已经发生或这个控件需要得到一些信息时,发送此消息给它的父窗口 
WM_INPUTLANGCHANGEREQUEST = $0050; 当用户选择某种输入语言,或输入语言的热键改变 
WM_INPUTLANGCHANGE = $0051; 当平台现场已经被改变后发送此消息给受影响的最顶级窗口 
WM_TCARD = $0052; 当程序已经初始化windows帮助例程时发送此消息给应用程序 
WM_HELP = $0053; 此消息显示用户按下了F1,如果某个菜单是激活的,就发送此消息个此窗口关联的菜单,否则就发送给有焦点的窗口,如果当前都没有焦点,就把此消息发送给当前激活的窗口 
WM_USERCHANGED = $0054; 当用户已经登入或退出后发送此消息给所有的窗口,当用户登入或退出时系统更新用户的具体设置信息,在用户更新设置时系统马上发送此消息; 
WM_NOTIFYFORMAT = $0055; 公用控件,自定义控件和他们的父窗口通过此消息来判断控件是使用ANSI还是UNICODE结构在WM_NOTIFY消息,使用此控件能使某个控件与它的父控件之间进行相互通信 
WM_CONTEXTMENU = $007B; 当用户某个窗口中点击了一下右键就发送此消息给这个窗口 
WM_STYLECHANGING = $007C; 当调用SETWINDOWLONG函数将要改变一个或多个窗口的风格时发送此消息给那个窗口 
WM_STYLECHANGED = $007D; 当调用SETWINDOWLONG函数一个或多个 窗口的风格后发送此消息给那个窗口 
WM_DISPLAYCHANGE = $007E; 当显示器的分辨率改变后发送此消息给所有的窗口 
WM_GETICON = $007F; 此消息发送给某个窗口来返回与某个窗口有关连的大图标或小图标的句柄; 
WM_SETICON = $0080; 程序发送此消息让一个新的大图标或小图标与某个窗口关联; 
WM_NCCREATE = $0081; 当某个窗口第一次被创建时,此消息在WM_CREATE消息发送前发送; 
WM_NCDESTROY = $0082; 此消息通知某个窗口,非客户区正在销毁 
WM_NCCALCSIZE = $0083; 当某个窗口的客户区域必须被核算时发送此消息 
WM_NCHITTEST = $0084; 移动鼠标,按住或释放鼠标时发生 
WM_NCPAINT = $0085; 程序发送此消息给某个窗口当它(窗口)的框架必须被绘制时; 
WM_NCACTIVATE = $0086; 此消息发送给某个窗口 仅当它的非客户区需要被改变来显示是激活还是非激活状态; 
WM_GETDLGCODE = $0087; 发送此消息给某个与对话框程序关联的控件,widdows控制方位键和TAB键使输入进入此控件通过响应WM_GETDLGCODE消息,应用程序可以把他当成一个特殊的输入控件并能处理它 
WM_NCMOUSEMOVE = $00A0; 当光标在一个窗口的非客户区内移动时发送此消息给这个窗口,非客户区为:窗体的标题栏及窗的边框体 
WM_NCLBUTTONDOWN = $00A1; 当光标在一个窗口的非客户区同时按下鼠标左键时提交此消息 
WM_NCLBUTTONUP = $00A2; 当用户释放鼠标左键同时光标某个窗口在非客户区十发送此消息; 
WM_NCLBUTTONDBLCLK = $00A3; 当用户双击鼠标左键同时光标某个窗口在非客户区十发送此消息 
WM_NCRBUTTONDOWN = $00A4; 当用户按下鼠标右键同时光标又在窗口的非客户区时发送此消息 
WM_NCRBUTTONUP = $00A5; 当用户释放鼠标右键同时光标又在窗口的非客户区时发送此消息 
WM_NCRBUTTONDBLCLK = $00A6; 当用户双击鼠标右键同时光标某个窗口在非客户区十发送此消息 
WM_NCMBUTTONDOWN = $00A7; 当用户按下鼠标中键同时光标又在窗口的非客户区时发送此消息 
WM_NCMBUTTONUP = $00A8; 当用户释放鼠标中键同时光标又在窗口的非客户区时发送此消息 
WM_NCMBUTTONDBLCLK = $00A9; 当用户双击鼠标中键同时光标又在窗口的非客户区时发送此消息 
WM_KEYFIRST = $0100; 
WM_KEYDOWN = $0100; 按下一个键 
WM_KEYUP = $0101; 释放一个键 
WM_CHAR = $0102; 按下某键,并已发出WM_KEYDOWNWM_KEYUP消息 
WM_DEADCHAR = $0103; 当用translatemessage函数翻译WM_KEYUP消息时发送此消息给拥有焦点的窗口 
WM_SYSKEYDOWN = $0104; 当用户按住ALT键同时按下其它键时提交此消息给拥有焦点的窗口; 
WM_SYSKEYUP = $0105; 当用户释放一个键同时ALT 键还按着时提交此消息给拥有焦点的窗口 
WM_SYSCHAR = $0106; WM_SYSKEYDOWN消息被TRANSLATEMESSAGE函数翻译后提交此消息给拥有焦点的窗口 
WM_SYSDEADCHAR = $0107; WM_SYSKEYDOWN消息被TRANSLATEMESSAGE函数翻译后发送此消息给拥有焦点的窗口 
WM_KEYLAST = $0108; 
WM_INITDIALOG = $0110; 在一个对话框程序被显示前发送此消息给它,通常用此消息初始化控件和执行其它任务 
WM_COMMAND = $0111; 当用户选择一条菜单命令项或当某个控件发送一条消息给它的父窗口,一个快捷键被翻译 
WM_SYSCOMMAND = $0112; 当用户选择窗口菜单的一条命令或当用户选择最大化或最小化时那个窗口会收到此消息 
WM_TIMER = $0113; 发生了定时器事件 
WM_HSCROLL = $0114; 当一个窗口标准水平滚动条产生一个滚动事件时发送此消息给那个窗口,也发送给拥有它的控件 
WM_VSCROLL = $0115; 当一个窗口标准垂直滚动条产生一个滚动事件时发送此消息给那个窗口也,发送给拥有它的控件 
WM_INITMENU = $0116; 当一个菜单将要被激活时发送此消息,它发生在用户菜单条中的某项或按下某个菜单键,它允许程序在显示前更改菜单 
WM_INITMENUPOPUP = $0117; 当一个下拉菜单或子菜单将要被激活时发送此消息,它允许程序在它显示前更改菜单,而不要改变全部 
WM_MENUSELECT = $011F; 当用户选择一条菜单项时发送此消息给菜单的所有者(一般是窗口) 
WM_MENUCHAR = $0120; 当菜单已被激活用户按下了某个键(不同于加速键),发送此消息给菜单的所有者; 
WM_ENTERIDLE = $0121; 当一个模态对话框或菜单进入空载状态时发送此消息给它的所有者,一个模态对话框或菜单进入空载状态就是在处理完一条或几条先前的消息后没有消息它的列队中等待 
WM_MENURBUTTONUP = $0122; 
WM_MENUDRAG = $0123; 
WM_MENUGETOBJECT = $0124; 
WM_UNINITMENUPOPUP = $0125; 
WM_MENUCOMMAND = $0126; 
WM_CHANGEUISTATE = $0127; 
WM_UPDATEUISTATE = $0128; 
WM_QUERYUISTATE = $0129; 
WM_CTLCOLORMSGBOX = $0132; windows绘制消息框前发送此消息给消息框的所有者窗口,通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置消息框的文本和背景颜色 
WM_CTLCOLOREDIT = $0133; 当一个编辑型控件将要被绘制时发送此消息给它的父窗口;通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置编辑框的文本和背景颜色 
WM_CTLCOLORLISTBOX = $0134; 当一个列表框控件将要被绘制前发送此消息给它的父窗口;通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置列表框的文本和背景颜色 
WM_CTLCOLORBTN = $0135; 当一个按钮控件将要被绘制时发送此消息给它的父窗口;通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置按纽的文本和背景颜色 
WM_CTLCOLORDLG = $0136; 当一个对话框控件将要被绘制前发送此消息给它的父窗口;通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置对话框的文本背景颜色 
WM_CTLCOLORSCROLLBAR = $0137; 当一个滚动条控件将要被绘制时发送此消息给它的父窗口;通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置滚动条的背景颜色 
WM_CTLCOLORSTATIC= $0138; 当一个静态控件将要被绘制时发送此消息给它的父窗口;通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置静态控件的文本和背景颜色 
WM_MOUSEFIRST = $0200; 
WM_MOUSEMOVE = $0200; 移动鼠标 
WM_LBUTTONDOWN = $0201; 按下鼠标左键 
WM_LBUTTONUP = $0202; 释放鼠标左键 
WM_LBUTTONDBLCLK = $0203; 双击鼠标左键 
WM_RBUTTONDOWN = $0204; 按下鼠标右键 
WM_RBUTTONUP = $0205; 释放鼠标右键 
WM_RBUTTONDBLCLK = $0206; 双击鼠标右键 
WM_MBUTTONDOWN = $0207; 按下鼠标中键 
WM_MBUTTONUP = $0208; 释放鼠标中键 
WM_MBUTTONDBLCLK = $0209; 双击鼠标中键 
WM_MOUSEWHEEL = $020A; 当鼠标轮子转动时发送此消息个当前有焦点的控件 
WM_MOUSELAST = $020A; 
WM_PARENTNOTIFY = $0210; MDI子窗口被创建或被销毁,或用户按了一下鼠标键而光标在子窗口上时发送此消息给它的父窗口 
WM_ENTERMENULOOP = $0211; 发送此消息通知应用程序的主窗口that已经进入了菜单循环模式 
WM_EXITMENULOOP = $0212; 发送此消息通知应用程序的主窗口that已退出了菜单循环模式 
WM_NEXTMENU = $0213; 
WM_SIZING = 532; 当用户正在调整窗口大小时发送此消息给窗口;通过此消息应用程序可以监视窗口大小和位置也可以修改他们 
WM_CAPTURECHANGED = 533; 发送此消息 给窗口当它失去捕获的鼠标时; 
WM_MOVING = 534; 当用户在移动窗口时发送此消息,通过此消息应用程序可以监视窗口大小和位置 也可以修改他们; 
WM_POWERBROADCAST = 536; 此消息发送给应用程序来通知它有关电源管理事件; 
WM_DEVICECHANGE = 537; 当设备的硬件配置改变时发送此消息给应用程序或设备驱动程序 
WM_IME_STARTCOMPOSITION = $010D; 
WM_IME_ENDCOMPOSITION = $010E; 
WM_IME_COMPOSITION = $010F; 
WM_IME_KEYLAST = $010F; 
WM_IME_SETCONTEXT = $0281; 
WM_IME_NOTIFY = $0282; 
WM_IME_CONTROL = $0283; 
WM_IME_COMPOSITIONFULL = $0284; 
WM_IME_SELECT = $0285; 
WM_IME_CHAR = $0286; 
WM_IME_REQUEST = $0288; 
 
  
WM_IME_KEYDOWN = $0290; 
WM_IME_KEYUP = $0291; 
WM_MDICREATE = $0220; 应用程序发送此消息给多文档的客户窗口来创建一个MDI 子窗口 
WM_MDIDESTROY = $0221; 应用程序发送此消息给多文档的客户窗口来关闭一个MDI 子窗口 
WM_MDIACTIVATE = $0222; 应用程序发送此消息给多文档的客户窗口通知客户窗口激活另一个MDI子窗口,当客户窗口收到此消息后,它发出WM_MDIACTIVE消息给MDI子窗口(未激活)激活它; 
WM_MDIRESTORE = $0223; 程序发送此消息给MDI客户窗口让子窗口从最大最小化恢复到原来大小 
WM_MDINEXT = $0224; 程序发送此消息给MDI客户窗口激活下一个或前一个窗口 
WM_MDIMAXIMIZE = $0225; 程序发送此消息给MDI客户窗口来最大化一个MDI子窗口; 
WM_MDITILE = $0226; 程序发送此消息给MDI客户窗口以平铺方式重新排列所有MDI子窗口 
WM_MDICASCADE = $0227; 程序发送此消息给MDI客户窗口以层叠方式重新排列所有MDI子窗口 
WM_MDIICONARRANGE = $0228; 程序发送此消息给MDI客户窗口重新排列所有最小化的MDI子窗口 
WM_MDIGETACTIVE = $0229; 程序发送此消息给MDI客户窗口来找到激活的子窗口的句柄 
WM_MDISETMENU = $0230; 程序发送此消息给MDI客户窗口用MDI菜单代替子窗口的菜单 
WM_ENTERSIZEMOVE = $0231; 
WM_EXITSIZEMOVE = $0232; 
WM_DROPFILES = $0233; 
WM_MDIREFRESHMENU = $0234; 
WM_MOUSEHOVER = $02A1; 
WM_MOUSELEAVE = $02A3; 
WM_CUT = $0300; 程序发送此消息给一个编辑框或combobox来删除当前选择的文本 
WM_COPY = $0301; 程序发送此消息给一个编辑框或combobox来复制当前选择的文本到剪贴板 
WM_PASTE = $0302; 程序发送此消息给editcontrolcombobox从剪贴板中得到数据 
WM_CLEAR = $0303; 程序发送此消息给editcontrolcombobox清除当前选择的内容; 
WM_UNDO = $0304; 程序发送此消息给editcontrolcombobox撤消最后一次操作 
WM_RENDERFORMAT = $0305 
WM_RENDERALLFORMATS = $0306; 
WM_DESTROYCLIPBOARD = $0307; 当调用ENPTYCLIPBOARD函数时 发送此消息给剪贴板的所有者 
WM_DRAWCLIPBOARD = $0308; 当剪贴板的内容变化时发送此消息给剪贴板观察链的第一个窗口;它允许用剪贴板观察窗口来显示剪贴板的新内容; 
WM_PAINTCLIPBOARD = $0309; 当剪贴板包含CF_OWNERDIPLAY格式的数据并且剪贴板观察窗口的客户区需要重画; 
WM_VSCROLLCLIPBOARD = $030A; 
WM_SIZECLIPBOARD = $030B; 当剪贴板包含CF_OWNERDIPLAY格式的数据并且剪贴板观察窗口的客户区域的大小已经改变是此消息通过剪贴板观察窗口发送给剪贴板的所有者; 
WM_ASKCBFORMATNAME = $030C; 通过剪贴板观察窗口发送此消息给剪贴板的所有者来请求一个CF_OWNERDISPLAY格式的剪贴板的名字 
WM_CHANGECBCHAIN = $030D; 当一个窗口从剪贴板观察链中移去时发送此消息给剪贴板观察链的第一个窗口; 
WM_HSCROLLCLIPBOARD = $030E; 此消息通过一个剪贴板观察窗口发送给剪贴板的所有者 ;它发生在当剪贴板包含CFOWNERDISPALY格式的数据并且有个事件在剪贴板观察窗的水平滚动条上;所有者应滚动剪贴板图象并更新滚动条的值; 
WM_QUERYNEWPALETTE = $030F; 此消息发送给将要收到焦点的窗口,此消息能使窗口在收到焦点时同时有机会实现他的逻辑调色板 
WM_PALETTEISCHANGING = $0310; 当一个应用程序正要实现它的逻辑调色板时发此消息通知所有的应用程序 
WM_PALETTECHANGED = $0311; 此消息在一个拥有焦点的窗口实现它的逻辑调色板后发送此消息给所有顶级并重叠的窗口,以此来改变系统调色板 
WM_HOTKEY = $0312; 当用户按下由REGISTERHOTKEY函数注册的热键时提交此消息 
WM_PRINT = 791; 应用程序发送此消息仅当WINDOWS或其它应用程序发出一个请求要求绘制一个应用程序的一部分; 
WM_PRINTCLIENT = 792; 
WM_HANDHELDFIRST = 856; 
WM_HANDHELDLAST = 863; 
WM_PENWINFIRST = $0380; 
WM_PENWINLAST = $038F; 
WM_COALESCE_FIRST = $0390; 
WM_COALESCE_LAST = $039F; 
WM_DDE_FIRST = $03E0; 
WM_DDE_INITIATE = WM_DDE_FIRST + 0; 一个DDE客户程序提交此消息开始一个与服务器程序的会话来响应那个指定的程序和主题名; 
WM_DDE_TERMINATE = WM_DDE_FIRST + 1; 一个DDE应用程序(无论是客户还是服务器)提交此消息来终止一个会话; 
WM_DDE_ADVISE = WM_DDE_FIRST + 2; 一个DDE客户程序提交此消息给一个DDE服务程序来请求服务器每当数据项改变时更新它 
WM_DDE_UNADVISE = WM_DDE_FIRST + 3; 一个DDE客户程序通过此消息通知一个DDE服务程序不更新指定的项或一个特殊的剪贴板格式的项 
WM_DDE_ACK = WM_DDE_FIRST + 4; 此消息通知一个DDE(动态数据交换)程序已收到并正在处理WM_DDE_POKE, WM_DDE_EXECUTE, WM_DDE_DATA, WM_DDE_ADVISE, WM_DDE_UNADVISE, or WM_DDE_INITIAT消息 
WM_DDE_DATA = WM_DDE_FIRST + 5; 一个DDE服务程序提交此消息给DDE客户程序来传递个一数据项给客户或通知客户的一条可用数据项 
WM_DDE_REQUEST = WM_DDE_FIRST + 6; 一个DDE客户程序提交此消息给一个DDE服务程序来请求一个数据项的值; 
WM_DDE_POKE = WM_DDE_FIRST + 7; 一个DDE客户程序提交此消息给一个DDE服务程序,客户使用此消息来请求服务器接收一个未经同意的数据项;服务器通过答复WM_DDE_ACK消息提示是否它接收这个数据项; 
WM_DDE_EXECUTE = WM_DDE_FIRST + 8; 一个DDE客户程序提交此消息给一个DDE服务程序来发送一个字符串给服务器让它象串行命令一样被处理,服务器通过提交WM_DDE_ACK消息来作回应; 
WM_DDE_LAST = WM_DDE_FIRST + 8; 
WM_APP = $8000; 
WM_USER = $0400; 此消息能帮助应用程序自定义私有消息; 
 
  
通知消息(Notification message)是指这样一种消息,一个窗口内的子控件发生了一些事情,需要通知父窗口。通知消息只适用于标准的窗口控件如按钮、列表框、组合框、编辑框,以及Windows 95公共控件如树状视图、列表视图等。例如,单击或双击一个控件、在控件中选择部分文本、操作控件的滚动条都会产生通知消息。 
 
  
Button 
BN_CLICKED 用户单击了按钮 
BN_DISABLE 按钮被禁止 
BN_DOUBLECLICKED 用户双击了按钮 
BN_HILITE 用户加亮了按钮 
BN_PAINT 按钮应当重画 
BN_UNHILITE 加亮应当去掉 
 
  
ComboBox 
CBN_CLOSEUP 组合框的列表框被关闭 
CBN_DBLCLK 用户双击了一个字符串 
CBN_DROPDOWN 组合框的列表框被拉出 
CBN_EDITCHANGE 用户修改了编辑框中的文本 
CBN_EDITUPDATE 编辑框内的文本即将更新 
CBN_ERRSPACE 组合框内存不足 
CBN_KILLFOCUS 组合框失去输入焦点 
CBN_SELCHANGE 在组合框中选择了一项 
CBN_SELENDCANCEL 用户的选择应当被取消 
CBN_SELENDOK 用户的选择是合法的 
CBN_SETFOCUS 组合框获得输入焦点 
 
  
 
  
Edit 
EN_CHANGE 编辑框中的文本己更新 
EN_ERRSPACE 编辑框内存不足 
EN_HSCROLL 用户点击了水平滚动条 
EN_KILLFOCUS 编辑框正在失去输入焦点 
EN_MAXTEXT 插入的内容被截断 
EN_SETFOCUS 编辑框获得输入焦点 
EN_UPDATE 编辑框中的文本将要更新 
EN_VSCROLL 用户点击了垂直滚动条消息含义 
 
  
Listbox 
LBN_DBLCLK 用户双击了一项 
LBN_ERRSPACE 列表框内存不够 
LBN_KILLFOCUS 列表框正在失去输入焦点 
LBN_SELCANCEL 选择被取消 
LBN_SELCHANGE 选择了另一项 
LBN_SETFOCUS 列表框获得输入焦点

你可能感兴趣的:(xhtml,ui,前端)