The CFScript syntax provides a way of writing CFML code without using tags. CFScript can either be in a script based component (CFC) or inside the cfscript tag.
Description
Encloses a code block that contains cfscript statements.
Category
Syntax
<cfscript> // cfscript code here </cfscript>
See also
cfinvoke, cfmessagebox, CreateObject; Extending ColdFusion Pages with CFML Scripting in the Developing ColdFusion Applications
History
ColdFusion 11: Enhanced support like usage of custom tags.
ColdFusion MX:
- Changed how to invoke component methods: this tag can now invoke component methods, using the CreateObject function
- Changed use of reserved words: you cannot use ColdFusion reserved words within this tag
- Added the try and catch statements.
Usage
Performs processing in CFScript. This tag uses ColdFusion functions, expressions, and operators. You can read and write ColdFusion variables within this tag. For a detailed description of the CFScript scripting language, including documentation of CFScript statements and the CFScript equivalents of CFML tags, see Extending ColdFusion Pages with CFML Scripting in the Developing ColdFusion Applications.
You can use this tag to enclose a series of assignment statements that would otherwise require cfset statements.
If you code a cftry/cfcatch_ block within this tag using an exception's Java class name, provide the fullyqualified class name._
You cannot use some ColdFusion reserved words in this tag. You cannot put a user-defined function whose name begins with any of these strings within this tag:
- cf
- cf_
- _cf
- coldfusion
- coldfusion_
_coldfusion
You cannot use the elseif construct within a cfscripttag. You can use code such as the following:
else if ( condition ) { ... }
Keywords
The following words are now treated as keywords:
- import
- finally
- component
- interface
- pageencoding
For loop
<cfscript> myarr=[10,3,5,12,61]; sum=0; for (i=1;i<=ArrayLen(myarr);i++){ sum=sum+myarr[i]; } writeoutput("The sum of the elements in the array is: " & sum); </cfscript>
For-in loop
<cfscript> arr=["ColdFusion","Java","PHP","Ruby"]; for (i in arr){ writeOutput(i & " is a language" & "<br/>"); } </cfscript>
For-in loop (Struct)
<cfscript> myStruct=StructNew(); myStruct.name="ColdFusion"; myStruct.version="2016"; myStruct.os="Windows"; for (i in myStruct){ writeOutput(i & ":" & myStruct[i] & "<br/>"); } </cfscript>
If-Else
<cfscript> arr=[2,3,4,5,6,7]; // if-else if (ArraySum(arr)>=20){ WriteOutput("Sum is: " & ArraySum(arr)); } else{ WriteOutput("Less than: " & ArraySum(arr)); } </cfscript>
switch
<cfscript> myLang="ColdFusion"; switch (myLang){ case "Java": WriteOutput("Language is: " & myLang); break; case "PHP": WriteOutput("Language is: " & myLang); break; case "Ruby": WriteOutput("Language is: " & myLang); break; default: WriteOutput("Language is: " & myLang); break; } </cfscript>
arrayeach
<cfscript> myCities=["London","New York","Paris","Tokyo","Barcelona"]; // Create a function that takes city as an argument and prints the name of the cities as output // with delimiter as space ArrayEach(myCities,function(city){ WriteOutput(city & " "); } ); </cfscript>
structeach
<cfscript> myStruct=StructNew(); myStruct.m1="Hello"; myStruct.m2="World"; myStruct.time=now(); StructEach(myStruct,function(key,value){ WriteOutput(key & value & "<br/>"); }); </cfscript>
For loop (query)
<cfscript> myQuery=queryNew("empid,depid,name", "integer,integer,varchar",[ [10, 101, "John"], [20, 120, "James"], [30, 205, "Peter"], [40, 530, "Jacob"], [50, 306, "Mary"], [60, 120, "Helen"] ]); for (i in myQuery){ // Get rows WriteOutput("Row id: " & myQuery.CurrentRow & " " & "Emp id: " & i.empid & " " & "Name is: " & i.name & "<br/>"); } </cfscript>
ColdFusion components
// hello.cfc component displayname="greetings" { function sayHello(){ message="Hello World"; return message; } }
<cfscript> // instantiate object obj=new hello(); WriteOutput(obj.sayHello()); </cfscript>
Exception handling with the cfscript tag
To handle exceptions with this tag, use try and catch statements, which are equivalent to the cftry and cfcatch tags. For each try statement, you must have a catch statement. In the catch block, the variable exceptionVariable contains the exception type. This variable is the equivalent of the cfcatch tag built-in variable cfcatch.Type. For more information, see Extending ColdFusion Pages with CFML Scripting in the Developing ColdFusion Applications.
Invoking ColdFusion components with the cfscript tag
CFScript invokes component methods using the CreateObject function. The following example shows how to invoke a component object with the cfscript tag, using ordered arguments:
<cfscript> quote = CreateObject( "component", "nasdaq.quote" ) ; <!--- Invocation using ordered arguments. ---> res = quote.getLastTradePrice( "macr" ) ; </cfscript>
The following example shows how to use an attribute collection within the cfscript tag to pass parameters when invoking a component object. An attribute collection is a structure in which each key corresponds to a parameter name and each value is the parameter value passed for the corresponding key.
<cfscript> stArgs = structNew(); stArgs.zipcode = "55987"; </cfscript> ... <cfinvoke webservice = "http://www.xmethods.net/sd/2001/TemperatureService.wsdl" method = "getTemp" argumentCollection = "#stArgs#" returnVariable = "aTemp" > <cfoutput>The temperature at zip code 55987 is #aTemp#</cfoutput>
In this example, the structure is created in a cfscript block, but you can use any ColdFusion method to create the structure.
Consuming web services with the cfscript tag
The following example shows how to consume a web service with the cfscript tag. You use the CreateObject function to connect to the web service.
<cfscript> ws = CreateObject("webservice", "http://www.xmethods.net/sd/2001/TemperatureService.wsdl"); xlatstring = ws.getTemp("55987"); writeoutput(xlatstring); </cfscript>
For more information, see Using Web Services in the Developing ColdFusion Applications.
Script support for tags
ColdFusion traditionally allowed you to build your applications using simple tags. ColdFusion 11 allows you to write all the tags in the script format in a very generic manner. The format for the generic syntax is as follows:
<cfscript> cftag1 (att1=val1, att2=val2) // The parent tag { // First child tag having attributes in the parenthesis (Optional) child_Tag1 (child_attr1='cv1', child_attr2='cv2') { // Nested child tag child_childTag (child_child_attr1=ccv1, child_child_attr2=ccv2); } // Second child of parent tag child_Tag2 (child2_attr1='cv1', child2_attr2='cv2'); } </cfscript>
Note that the attributes of a tag must be enclosed within a parenthesis and also the attributes must be comma-separated.
Consider the following example:
<cfform name='myForm' action=''> <cfgrid name="myGrid" query='userNameQuery'> <cfgridcolumn name='firstName' id='firstName' type='string' /> <cfgridcolumn name='lastName' id='lastName' type='string' /> </cfgrid> </cfform>
You have been used to writing ColdFusion code as mentioned in the above example. To give you more control, invoking tags inside the ColdFusion script block is now supported.
So, now you can write your code in the following manner:
<cfscript> cfform (name='myForm', acton='') { cfgrid (name="myGrid", query='userNameQuery') { cfgridcolumn (name='firstName', id='firstName', type='string'); cfgridcolumn (name='lastName', id='LastName', type='string'); } } </cfscript>
The script support is not available for the following tags:
- <cfscript>
- <cfoutput> (use writeOutput() instead)
- <cfdump> (use writeDump() instead)
- <cfinvoke> (use invoke() instead)
- <cfinvokeargument>
- <cfobject> (use createObject instead)
Though the script equivalents of the above tags might work, they are not supported.
Using custom tags in scripts
Custom tags can also be used in <cfscript> blocks just like normal ColdFusion tags. For instance,
If there is a custom tag named cf_happybirthday to generate a birthday message which is used in the tag syntax like:
<cf_happybirthday name="Ted Cantor" birthDate="December 5, 1987">
The same can be written in the script syntax as :
cf_happybirthday (name="Ted Cantor", birthDate="December 5, 1987");
Also, script support for cfimport-based prefix custom tag is supported. You can use prefix-based custom tag in script blocks as follows:
<cfscript> cfimport(taglib=" ../importFolder/", prefix="myTags"); myTags:customTag(); </cfscript>
In the above example, customTag is a CFM file under the importFolder directory.
Example
<p>This simple example shows variable declaration and manipulation. <cfif IsDefined("form.myValue")> <cfif IsNumeric(form.myValue)> <cfset x = form.myValue> <cfscript> y = x; z = 2 * y; StringVar = form.myString; </cfscript> <cfoutput> <p>twice #x# is #z#. <p>Your string value was: <b><I>#StringVar#</i></b> </cfoutput> <cfelse>