473,386 Members | 1,795 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes and contribute your articles to a community of 473,386 developers and data experts.

Handling Optional Parameters in VBA

NeoPa
32,556 Expert Mod 16PB
Handling Optional Parameters in VBA

It seems there is no reliable way to handle these consistently for all variable types. Each has a different approach required, as I hope to illustrate below.


Variant Variables

Such variables can store all types of different values as well as objects, and they have a Missing flag which can be checked with the IsMissing() function.
Expand|Select|Wrap|Line Numbers
  1. Private Sub ProcName(Optional varX As Variant)
  2.     If IsMissing(varX) Then varX = ...
  3. End Sub

Standard Variables

These include Byte, Integer, Long, Single, Double, Currency, Decimal, Date & String. These are handled by assigning a default value as there is no bit specified to store a Missing flag.
Expand|Select|Wrap|Line Numbers
  1. Private Sub ProcName(Optional intX As Integer = -1)
  2.     If intX < 0 Then ...
  3. End Sub

Object Variables

Object variables, that is variables of any defined class (as opposed to the variable of specific type Object) also have no Missing flag available, so these come through when unset as Nothing.
Expand|Select|Wrap|Line Numbers
  1. Private Sub ProcName(Optional dbX As DAO.Database)
  2.     If dbX Is Nothing Then Set db = ...
  3. End Sub
I hope to clarify this further when I come across other types or other required approaches, but this is hard to find in the Help system so I wanted at least to have somewhere to refer to if I needed it again in future.
Dec 8 '11 #1
0 16710

Sign in to post your reply or Sign up for a free account.

Similar topics

3
by: Rane Bowen | last post by:
Hi, I am using python with a makepy generated wrapper on a COM application. One of this object's methods has 3 parameters, two of which are optional. If I call the method with just the...
2
by: Frank Rizzo | last post by:
Does c# support optional parameters in function declarations? Does it support assignment of default values to arguments, in particular optional parameters? If so, can someone point me to or...
0
by: lakshmi | last post by:
include the following lines of code: using System.Runtime.InteropServices; prefix the optional argument with This takes care if an optional parameter is not supplied by a VB script client....
16
by: ad | last post by:
Does C#2.0 support optional parameters like VB.NET: Function MyFunction(Optional ByVal isCenter As Boolean = False)
3
by: guy | last post by:
found this oddity- copying a vb6 function with optional parameters and pasting it into a vb2003 class, for conversion purposes, it all works fine except that the collapsing "-" on the LHS goes...
5
by: Water Cooler v2 | last post by:
So you have optional parameters for functions/methods in Visual Basic ..NET, but not in C#?
14
by: cody | last post by:
I got a similar idea a couple of months ago, but now this one will require no change to the clr, is relatively easy to implement and would be a great addition to C# 3.0 :) so here we go.. To...
12
by: pamelafluente | last post by:
Hi guys, In the past I have used several time optional parameters in my function. But Now I am more inclined to think that they are more dangerous than useful, and probably better to be...
7
by: Sam Shrefler | last post by:
I'm working on creating a WebService / WebMethod to receive a record in real time from another system. The record contains about 20 fields. 10 of which aren't required. I was planning on just...
1
by: peridian | last post by:
This is more of a general question, but I didn't know where to post it. Since Java is an example of a language which does this, I thought here would work. Coming from a C++ background, having...
0
by: taylorcarr | last post by:
A Canon printer is a smart device known for being advanced, efficient, and reliable. It is designed for home, office, and hybrid workspace use and can also be used for a variety of purposes. However,...
0
by: aa123db | last post by:
Variable and constants Use var or let for variables and const fror constants. Var foo ='bar'; Let foo ='bar';const baz ='bar'; Functions function $name$ ($parameters$) { } ...
0
by: ryjfgjl | last post by:
In our work, we often receive Excel tables with data in the same format. If we want to analyze these data, it can be difficult to analyze them because the data is spread across multiple Excel files...
1
by: nemocccc | last post by:
hello, everyone, I want to develop a software for my android phone for daily needs, any suggestions?
1
by: Sonnysonu | last post by:
This is the data of csv file 1 2 3 1 2 3 1 2 3 1 2 3 2 3 2 3 3 the lengths should be different i have to store the data by column-wise with in the specific length. suppose the i have to...
0
by: Hystou | last post by:
There are some requirements for setting up RAID: 1. The motherboard and BIOS support RAID configuration. 2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...
0
marktang
by: marktang | last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However,...
0
Oralloy
by: Oralloy | last post by:
Hello folks, I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>". The problem is that using the GNU compilers,...
0
jinu1996
by: jinu1996 | last post by:
In today's digital age, having a compelling online presence is paramount for businesses aiming to thrive in a competitive landscape. At the heart of this digital strategy lies an intricately woven...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.