VBS中Sub与Function的区别

 

 

VBSSubFunction的区别

VBscript中,有两种procedureSub procedureFunction procedure
一、Sub Procedures

    VBScriptSub ProcedureSub开始,以End Sub结束,中间是VBScript语句。Sub procedure完成一系列的动作,但是不产生返回值。Sub Procedure也可以携带参数(如常量、变量、或表达式)。如果Sub Procedure不携带参数,则Sub 语句也必须带有一对空括号。

下面的这个Sub Procedure例子使用了两个内建VBScript 函数 MsgBox以及InputBoxInputBox用来弹出提示框,提示用户输入相关信息;MsgBox用以显示计算结果。计算功能由用户自建的Function Procedure来实现,相关信息在接下来的内容中另行讨论。

代码:

   Sub ConvertTemp()
       temp = InputBox("Please enter the temperaturein degrees F.", 1)
       MsgBox "The temperature is " &Celsius(temp) & " degrees C."
    End Sub

二、
Function Procedures

    Function ProcedureFunction开始,以End Function结束,中间是VBScript语句。Function ProcedureSub Procedure相似,但是Function Procedure可以返回值。Function Procedure也可以携带参数(常量、变量、表达式)。如果Function Procedure不携带参数,Function语句也必须带有一对空括号。Function Procedure在语句中,通过赋值语句将值赋给Funciton的名称,由此Function Procedure得到返回值。返回值的数据类型总是Variant类型。

    在下面的例子中,用户定义的Function Celsius将华氏温度换算为摄氏度。当在Sub procedure ConvertTemp中用Celsius(temp)调用这个Function时,将参数“Temp”传到Function中(注意:此时参数Temp已经有明确的数据了)。然后在Function中,进行换算工作,并将换算结果赋给Function名称“Celsius”,由此换算结果就成了Function的返回值,返回给调用它的Sub procedure,并通过Message语句显示出来。

代码:


    Sub ConvertTemp()
       temp = InputBox("Please enter the temperaturein degrees F.", 1)
       MsgBox "The temperature is " &Celsius(temp) & " degrees C."
    End Sub
    Function Celsius(fDegrees)
       Celsius = (fDegrees - 32) * 5 / 9
    End Function

三、将数据传入或传出Procedure

    Procedure只能通过参数获得数据。参数名可以是任何有效的变量名称。用户可以用Sub语句或Function语句创建Procedure,无论是用哪种方式创建,Procedure名称后面都必须带有一对括号。所有的参数包括在这一对括号之中,用逗号分隔。

    在下面的例子中,“fDegrees”是一个参数,它将值传入Function“Celsius”

代码:

FunctionCelsius(fDegrees)
       Celsius = (fDegrees - 32) * 5 / 9
    End Function

    要想从procedure获取返回值,必需使用Funciton procedure。要记住:只有Function procedure有返回值,Sub procedure没有返回值。

三、如何在脚本中使用Sub ProcedureFunction Procedure

    Function总是放置于变量赋值语句的右侧,或放置于表达式中。如

代码:


    Temp=Celsius(fDegrees)
   

    MsgBox "The Celsius temperature is " &Celsius(fDegrees) & " degrees."

在调用Sub procedure时,在procedure名字后带上所有必须的参数,参数之间用逗号隔开。Call语句不是必须的,但是如果使用Call语句来调用它,procedure名字后面的参数必须用括号括起来。下面的例子表达了两种不同的调用方法:一个使用Call语句来调用,另一个没有使用Call语句。两种方法的是殊道同归。

代码:

    Call MyProc(firstarg, secondarg)
    MyProc firstarg, secondarg

  注意:在使用Call语句调用Sub Procedure时,参数必须用括号括起来。

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值