1、MsgBox函数用法讲解MsgBox函数用法讲解MsgBox函数用法讲解VBA中msgbox的用法小结1、作用在消息框中显示信息,并等待用户单击按钮,可返回单击的按钮值(比如“确定”或者“取消”)。通常用作显示变量值的一种方式。2、语法MsgBox(Prompt,Buttons,Title,Helpfile,Context)参数说明:(1)Prompt,必需的参数,为字符串,作为显示在消息框中的消息文本。其最大长度约为1024个字符,由所用字符的宽度决定。如果prompt的内容超过一行,则可以在每一行之间用回车符(Chr(13)、换行符(Chr(10)或是回车与换行符的组合(Chr(13)&C
2、hr(10)将各行分隔开来。(2)Buttons,可选的参数,为数值表达式的值之和,指定显示的按钮的数目及形式、使用的图标样式、缺省按钮及消息框的强制回应等,可以此定制消息框。若省略该参数,则其缺省值为0。设置值见下表。(3)Title,可选的参数,表示在消息框的标题栏中所显示的文本。若省略该参数,则将应用程序名放在标题栏中。(4)Helpfile,可选的参数,为字符串表达式,提供帮助文件。若有Helpfile,则必须有Context。(5)Context,可选的参数,为数值表达式,提供帮助主题。若有Context,则必须有Helpfile。vbNo 7 否5、相关说明(1) 如果同时提供了H
3、elpfile与Context参数,可以按F1键来查看与Context相应的帮助主题,Excel通常会在输入框中自动添加一个帮助(Help)按钮。(2)若在消息框中显示“取消”按钮,则按下ESC键与单击“取消”按钮效果相同。若消息框中有“帮助”按钮,则提供相关的帮助信息。(3)如果要输入多个参数并省略中间的某些参数,则必须在相应位置加入逗号分界符。6、示例(1)使用 MsgBox 函数,在具有“是”及“否”按钮的对话框中显示一条严重错误信息。示例中的缺省按钮为“否”,MsgBox函数的返回值视用户按哪一个钮而定。并假设DEMO.HLP为一帮助文件,其中有一个帮助主题代码为1000。Dim Ms
4、g,Style,Title,Help,Ctxt,Response,MyStringMsg=Do you want to continue ? 定义消息文本Style = vbYesNo + vbCritical + vbDefaultButton2 定义按钮Title = MsgBox Demonstration 定义标题文本Help = DEMO.HLP 定义帮助文件Ctxt = 1000 定义帮助主题Response = MsgBox(Msg, Style, Title, Help, Ctxt)If Response = vbYes Then 用户按下“是” MyString = Yes
5、完成某操作Else 用户按下“否” MyString = No 完成某操作End If(2)只显示某消息MsgBox “Hello!”(3)将消息框返回的结果赋值给变量Ans=MsgBox(“Continue?”,vbYesNo)If MsgBox(“Continue?”,vbYesNo)vbYes Then Exit Sub(4)使用常量的组合,赋值组Config变量,并设置第二个按钮为缺省按钮Config=vbYesNo+vbQuestion+vbDefaultButton2(5)若要在消息中强制换行,可在文本中使用vbCrLf(或vbNewLine)常量,用&加空格与字符隔开。如MsgB
6、ox “This is the first line.” & vbNewLine & “Second line.”(6)可以在消息框中使用vbTab常量插入一个制表符。下面的过程使用一个消息框来显示55单元格区域中的所有值,用vbTab常量分隔列并使用vbCrLf常量插入一个新行。注意在MsgBox函数最多只显示1024个字符,因此限制了可显示的单元格数。Option ExplicitSub ShowRangeValue()Dim Msg As StringDim r As Integer, c As IntegerMsg = For r = 1 To 5For c = 1 To 5 Msg
7、= Msg & Cells(r, c) & vbTabNext cMsg = Msg & vbCrLfNext rMsgBox MsgEnd Sub(7)在消息框语句中运用工作表函数以及设置显示的数置格式,如下面语句所示:MsgBox selection has & m & cells . & Chr(13) & the sum is : & Application.WorksheetFunction.Sum(Selection) & Chr(13) & the average is : & Format(Application.WorksheetFunction.Average(Select
8、ion), #,#0.00), vbInformation, selection count & sum & average & Chr(13)下面是具体的例子,配图MsgBox函数和MsgBox语句均可用来弹出对话框,不同处在于MsgBox函数可以返回一个值,而MsgBox语句不会返回值。MsgBox语句:用于弹出一个对话框。格式如下:MsgBox内容,类型,标题,帮助文件名,帮助主题目录号在IE地址栏中输入“javascript:alert(“欢迎XX”)”,然后按enter键,则弹出对话框“欢迎XX”VB中MsgBox语句也可方便实现,在窗体的单击事件中输入如下代码Private Sub
9、 Form_click()MsgBox (欢迎XX)End SubMsgBox内容,类型,标题,帮助文件名,帮助主题目录号“内容”参数,为必要参数,是一个字符串,其长度不得超过1024字符。如果超过,多余的部分会被省略。字符串的内容在由MsgBox语句弹出的对话框中显示。当字符串在一行内显示不完时,将自动换行。也可用“chr$(13)+chr$(10)”或“vbCrlf”进行强制换行。例如Private Sub Form_click()MsgBox 欢迎XX & Chr(13) + Chr(10) & 祝XX快乐每一天!End Sub运行后将弹出对话框如图:“类型”参数,它是一个整数值或符号常
10、量,用来控制在对话框内显示的按钮、图标的种类及数量。该参数的值由4类数值相加产生,这4类数值或符号常量分别表示按钮的类型、显示图标的种类、活动按钮的位置以及强制返回。不过,对于MsgBox语句,按钮的类型及强制返回作用不大,但对于MsgBox函数却很有用。在MsgBox函数中可通过按钮对话框中某个按钮而执行指定的操作。MsgBox类型参数的取值:符号常量值作 用按钮类型vbOKOnly0只显示“确定”按钮vbOKCancel1只显示“确定”及“取消”按钮vbAbortRetryIgnore2显示“放弃”、“重试”和“忽略”按钮vbYesNoCancel3显示“是”、“否”和“取消”按钮vbYe
11、sNo4显示“是”和“否”按钮vbRetryCancel5显示“重试”和“取消”按钮图标样式vbCritical16显示系统叉号图标vbQuestion32显示系统问号图标vbExclamation48显示系统叹号图标vbInformation64显示系统信息图标默认按钮vbDefaultButton10第一个按钮为默认按钮vbDefaultButton2256第二个按钮为默认按钮vbDefaultButton3512第三个按钮为默认按钮vbDefaultButton4768第四个按钮为默认按钮强制返回vbApplicationModal0应用程序强制返回vbSystemModal4096系统
12、强制返回例如:Private Sub Form_click()MsgBox 欢迎XX & Chr(13) + Chr(10) & 祝XX快乐每一天!,2End Sub运行后将弹出对话框如图:例如:Private Sub Form_click()MsgBox 欢迎XX & Chr(13) + Chr(10) & 祝XX快乐每一天!,64End Sub运行后将弹出对话框如图:如果要同时定义按钮类型和图标样式,可直接将按钮类型的取值和图标样式的取值相加即可。例如:2+64Private Sub Form_click()MsgBox 欢迎XX & Chr(13) + Chr(10) & 祝XX快乐每一
13、天!,66End Sub执行结果如图:Private Sub Form_click()MsgBox 欢迎XX & Chr(13) + Chr(10) & 祝XX快乐每一天!,66+512End Sub则会将默认按钮变为第三个按钮,执行结果如图:如果对话框中只有三个按钮,代码却为“66+768”,执行结果为默认选中第一个按钮。“标题”参数,用来指定对话框的标题栏文字。例如:Private Sub Form_click()MsgBox 欢迎XX & Chr(13) + Chr(10) & 祝XX快乐每一天!,65 + 512, 许愿池End Sub执行结果:*MsgBox函数,除可返回值外,其他功
14、能与MsgBox语句相同。MsgBox函数返回值是一个整数,可以是17之间的任意整数,它们分别对应7个按钮被选中的状态。返回值操 作符号常量1选“确定”按钮vbOk2选“取消”按钮vbCancel3选“终止”按钮vbAbort4选“重试”按钮 vbRetry5选“忽略”按钮 vblgnore6 选“是”按钮vbYes7选“否”按钮 vbNo例如:在按钮【退出】的双击事件中输入如下代码:Private Sub Command1_Click()Dim a As Integer 定义整形变量aa = MsgBox(你确定要退出吗?, 1 + 32) 用变量a来接收MsgBox函数的返回值If a = 1 Then 如果变量a的值为1,即MsgBox函数的返回值为1。那么EndElsePrint (你没有退出。)End IfEnd Sub
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1