ColdFusion 9.0 Resources |
Understanding variables and periodsContents [Hide]The following descriptions use a sample variable named MyVar.a.b to explain how ColdFusion uses periods when getting and setting the variable value. Getting a variableColdFusion can correctly get variable values even if the variable name includes a period. For example, the following set of steps shows how ColdFusion gets MyVar.a.b, as in <cfset Var2 = myVar.a.b> or IsDefined(myVar.a.b):
This way, ColdFusion correctly resolves the variable name and can get its value. You can also use array notation to get a simple variable with a name that includes periods. In this form of array notation, you use the scope name (or the complex variable that contains the simple variable) as the “array” name. You place the simple variable name, in single- or double-quotation marks, inside the brackets. Using array notation is more efficient than using plain dot notation because ColdFusion does not have to analyze and look up all the possible key combinations. For example, both of the following lines write the value of myVar.a.b, but the second line is more efficient than the first: <cfoutput>myVar.a.b is: #myVar.a.b#<br></cfoutput> <cfoutput>myVar.a.b is: #Variables["myVar.a.b"]#<br></cfoutput> Setting a variableColdFusion cannot be as flexible when it sets a variable value as when it gets a variable, because it must determine the type of variable to create or set. Therefore, the rules for variable names that you set are stricter. Also, the rules vary depending on whether the first part of the variable name is the Cookie or Client scope identifier. For example, assume that you have the following code: <cfset myVar.a.b = "This is a test"> If a variable myVar does not exist, it does the following:
If either myVar or myVar.a exist and neither one is a structure, ColdFusion generates an error. In other words, ColdFusion uses the same rules as for getting a variable to resolve the variable name until it finds a name that does not exist yet. It then creates any structures that are needed to create a key named b inside a structure, and assigns the value to the key. However, if the name before the first period is either Cookie or Client, ColdFusion uses a different rule. It treats all the text (including any periods) that follow the scope name as the name of a simple variable, because Cookie and Client scope variables must be simple. If you have the following code, you see that ColdFusion creates a single, simple Client scope variable named myVar.a.b: <cfset Client.myVar.a.b = "This is a test"> <cfdump var=#Client.myVar.a.b#> |