VBScript Variables
What Is a Variable?
A variable is a convenient placeholder that refers to a computer memory location where you can store program information that may change during the time your script is running. For example, you might create a variable called ClickCount to store the number of times a user clicked an object on a particular Web page. Where the variable is located in computer memory is unimportant. What's important is that you only have to refer to it by name to see its value or to change its value. In VBScript, variables are always of one fundamental data type, Variant.
Declaring Variables
You declare variables explicitly in your script using the Dim statement. For example:
<SCRIPT LANGUAGE="VBScript"> <!-- Dim DegreesFahrenheit --> </SCRIPT>You declare multiple variables by separating each variable name with a comma. For example:
<SCRIPT LANGUAGE="VBScript"> <!-- Dim Top, Bottom, Left, Right --> </SCRIPT>You can also declare a variable implicitly by simply using its name somewhere in your script. That's not generally considered to be a good practice because you could misspell the variable name in one or more places, causing unexpected results when your script is run. For that reason, the Option Explicit statement is available to require explicit declaration of all variables. The Option Explicit statement should be the first statement inside your <SCRIPT> tag.
Naming Restrictions
Variable names follow the standard rules for naming anything in VBScript. A variable name:
- Must begin with an alphabetic character.
- Cannot contain an embedded period.
- Must not exceed 255 characters.
- Must be unique in the scope in which it is declared.
Scope and Lifetime of Variables
Generally, when you declare a variable within a procedure, only code within that procedure can access or change the value of that variable; it has local scope and is known as a procedure-level variable. Sometimes, however, you need to use a variable with a broader scope, such as one whose value is available to all the procedures within the same script. If you declare a variable outside a procedure, you make it recognizable to all the procedures in your script. This kind of script-level variable is said to have script-level scope.The length of time a variable exists is its lifetime. A script-level variable's lifetime extends from the time it is declared until the time the script is finished running. A local variable's lifetime begins when its declaration statement is encountered as the procedure begins, and ends when the procedure concludes. Local variables are ideal as temporary storage space when a procedure is executing. You can have local variables of the same name in several different procedures because each is recognized only by the procedure in which it is declared.
A variable's scope is determined by where you declare it. At script level, the lifetime of a variable is always the same. It exists for as long as the script is running. At procedure level, a variable exists only so long as you are in the procedure. When the procedure exits, the variable is destroyed.
Assigning Values to Variables
Values are assigned to variables creating an expression as follows: the variable is on the left side of the expression and the value you want to assign to the variable is on the right. For example:
<SCRIPT LANGUAGE="VBScript"> <!-- B = 200 --> </SCRIPT>Scalars and Arrays
Much of the time, you just want to assign a single value to a variable you've declared. A variable containing a single value is a scalar variable. Other times, it's convenient to assign more than one related value to a single variable. Then you can create a variable that can contain a series of values. This is called an array variable. Array variables are declared much the same way as scalar variables. The difference is that a declaration of an array variable uses parentheses following the variable name. In the following example, a single-dimension array containing 11 elements is declared:
<SCRIPT LANGUAGE="VBScript"> <!-- Dim A(10) --> </SCRIPT>Although the number shown in the parentheses is 10, all arrays in VBScript are zero-based, so this array actually contains 11 elements. In a zero-based array, the number of array elements is always the number shown in parentheses plus one. This kind of an array is called a fixed-size array.You assign data to each of the elements of the array using an index into the array. Beginning at zero and ending at 10, data can be assigned to the elements of an array as follows:
<SCRIPT LANGUAGE="VBScript"> <!-- A(0) = 256 A(1) = 324 A(2) = 100 . . . A(10) = 55 --> </SCRIPT>Similarly, the data can be retrieved from any element using an index into the particular array element you want. For example:
<SCRIPT LANGUAGE="VBScript"> <!-- . . . SomeVariable = A(8) . . . --> </SCRIPT>Arrays aren't limited to a single dimension. You can have as many of 60 dimensions although most people can't comprehend more than about three or four. Multiple dimensions are declared by separating an array's size numbers in the parentheses with commas. In the following example, the MyTable variable is a two-dimensional array consisting of 6 rows and 11 columns:
<SCRIPT LANGUAGE="VB"> <!-- Dim MyTable(5, 10) --> </SCRIPT>In a two-dimensional array, the first number is always the number of rows; the second the number of columns.You can also declare an array whose size changes during the time your script is running. This is called a dynamic array. The array is initially declared within a procedure using either the Dim statement as with any other array, or the ReDim statement. The difference is that no size or number of dimensions is placed inside the parentheses. For example:
<SCRIPT LANGUAGE="VBScript"> <!-- Dim MyArray() ReDim AnotherArray() --> </SCRIPT>To use a dynamic array, you must subsequently use ReDim to determine the number of dimensions and the size of each. In the following example, ReDim sets the initial size of the dynamic array to 25. A subsequent ReDim statement resizes the array to 30, but uses the Preserve keyword to preserve the contents of the array as the resizing takes place.
<SCRIPT LANGUAGE="VBScript"> <!-- ReDim MyArray(25) . . . ReDim Preserve MyArray(30) --> </SCRIPT>There is no limit to the number of times you can resize a dynamic array, but you should know that if you make an array smaller than it was, you lose the data in the eliminated elements.
© 1996 by Microsoft Corporation.