2015-10-05 23:52:07 +03:00
---
2015-10-18 19:56:16 +03:00
language: coldfusion
filename: learncoldfusion.cfm
2015-10-05 23:52:07 +03:00
contributors:
- ["Wayne Boka", "http://wboka.github.io"]
2015-10-31 03:15:06 +03:00
- ["Kevin Morris", "https://twitter.com/kevinmorris"]
2015-10-05 23:52:07 +03:00
---
ColdFusion is a scripting language for web development.
[Read more here. ](http://www.adobe.com/products/coldfusion-family.html )
2015-10-31 03:15:06 +03:00
### CFML
_**C**old**F**usion **M**arkup **L**anguage_
ColdFusion started as a tag-based language. Almost all functionality is available using tags.
2015-10-07 23:54:19 +03:00
2017-01-01 02:36:08 +03:00
```cfm
2015-10-07 23:54:19 +03:00
< em > HTML tags have been provided for output readability< / em >
2015-10-05 23:52:07 +03:00
<!-- - Comments start with "<! - - - " and end with " - --> " --->
2015-10-06 04:07:13 +03:00
<!-- -
2015-10-05 23:52:07 +03:00
Comments can
2015-10-06 04:07:13 +03:00
also
2015-10-05 23:52:07 +03:00
span
multiple lines
--->
<!-- - CFML tags have a similar format to HTML tags. - -->
2015-10-07 23:54:19 +03:00
< h1 > Simple Variables< / h1 >
2015-10-05 23:52:07 +03:00
<!-- - Variable Declaration: Variables are loosely typed, similar to javascript - -->
2015-10-07 23:54:19 +03:00
< p > Set < b > myVariable< / b > to "myValue"< / p >
2015-10-05 23:52:07 +03:00
< cfset myVariable = "myValue" / >
2015-10-07 23:54:19 +03:00
< p > Set < b > myNumber< / b > to 3.14< / p >
2015-10-05 23:52:07 +03:00
< cfset myNumber = 3.14 / >
<!-- - Displaying simple data - -->
<!-- - Use <cfoutput> for simple values such as strings, numbers, and expressions - -->
2015-10-07 23:54:19 +03:00
< p > Display < b > myVariable< / b > : < cfoutput > #myVariable#< / cfoutput > < / p > <!-- - myValue - -->
< p > Display < b > myNumber< / b > : < cfoutput > #myNumber#< / cfoutput > < / p > <!-- - 3.14 - -->
2015-10-06 04:07:13 +03:00
< hr / >
2015-10-05 23:52:07 +03:00
2015-10-07 23:54:19 +03:00
< h1 > Complex Variables< / h1 >
2015-10-05 23:52:07 +03:00
<!-- - Declaring complex variables - -->
<!-- - Declaring an array of 1 dimension: literal or bracket notation - -->
2015-10-07 23:54:19 +03:00
< p > Set < b > myArray1< / b > to an array of 1 dimension using literal or bracket notation< / p >
2015-10-05 23:52:07 +03:00
< cfset myArray1 = [] / >
<!-- - Declaring an array of 1 dimension: function notation - -->
2015-10-07 23:54:19 +03:00
< p > Set < b > myArray2< / b > to an array of 1 dimension using function notation< / p >
2015-10-05 23:52:07 +03:00
< cfset myArray2 = ArrayNew(1) / >
<!-- - Outputting complex variables - -->
2015-10-07 23:54:19 +03:00
< p > Contents of < b > myArray1< / b > < / p >
2015-10-05 23:52:07 +03:00
< cfdump var = "#myArray1#" / > <!-- - An empty array object - -->
2015-10-07 23:54:19 +03:00
< p > Contents of < b > myArray2< / b > < / p >
< cfdump var = "#myArray2#" / > <!-- - An empty array object - -->
2015-10-05 23:52:07 +03:00
<!-- - Operators - -->
<!-- - Arithmetic - -->
2015-10-07 23:54:19 +03:00
< h1 > Operators< / h1 >
< h2 > Arithmetic< / h2 >
< p > 1 + 1 = < cfoutput > #1 + 1#< / cfoutput > < / p >
< p > 10 - 7 = < cfoutput > #10 - 7#< br / > < / cfoutput > < / p >
< p > 15 * 10 = <cfoutput>#15 * 10#< br /></ cfoutput ></ p >
< p > 100 / 5 = < cfoutput > #100 / 5#< br / > < / cfoutput > < / p >
< p > 120 % 5 = < cfoutput > #120 % 5#< br / > < / cfoutput > < / p >
< p > 120 mod 5 = < cfoutput > #120 mod 5#< br / > < / cfoutput > < / p >
2015-10-06 04:07:13 +03:00
< hr / >
2015-10-05 23:52:07 +03:00
<!-- - Comparison - -->
2015-10-07 23:54:19 +03:00
< h2 > Comparison< / h2 >
< h3 > Standard Notation< / h3 >
< p > Is 1 eq 1? < cfoutput > #1 eq 1#< / cfoutput > < / p >
< p > Is 15 neq 1? < cfoutput > #15 neq 1#< / cfoutput > < / p >
< p > Is 10 gt 8? < cfoutput > #10 gt 8#< / cfoutput > < / p >
< p > Is 1 lt 2? < cfoutput > #1 lt 2#< / cfoutput > < / p >
< p > Is 10 gte 5? < cfoutput > #10 gte 5#< / cfoutput > < / p >
< p > Is 1 lte 5? < cfoutput > #1 lte 5#< / cfoutput > < / p >
< h3 > Alternative Notation< / h3 >
< p > Is 1 == 1? < cfoutput > #1 eq 1#< / cfoutput > < / p >
< p > Is 15 != 1? < cfoutput > #15 neq 1#< / cfoutput > < / p >
< p > Is 10 > 8? < cfoutput > #10 gt 8#< / cfoutput > < / p >
< p > Is 1 < 2 ? < cfoutput > #1 lt 2#< / cfoutput > < / p >
< p > Is 10 >= 5? < cfoutput > #10 gte 5#< / cfoutput > < / p >
< p > Is 1 < = 5? < cfoutput > #1 lte 5#< / cfoutput > < / p >
2015-10-06 04:07:13 +03:00
< hr / >
2015-10-05 23:52:07 +03:00
<!-- - Control Structures - -->
2015-10-07 23:54:19 +03:00
< h1 > Control Structures< / h1 >
2015-10-05 23:52:07 +03:00
< cfset myCondition = "Test" / >
2015-10-07 23:54:19 +03:00
< p > Condition to test for: "< cfoutput > #myCondition#< / cfoutput > "< / p >
2015-10-05 23:52:07 +03:00
< cfif myCondition eq " Test " >
2015-10-07 23:54:19 +03:00
< cfoutput > #myCondition#. We're testing.< / cfoutput >
2015-10-05 23:52:07 +03:00
< cfelseif myCondition eq " Production " >
< cfoutput > #myCondition#. Proceed Carefully!!!< / cfoutput >
< cfelse >
myCondition is unknown
< / cfif >
2015-10-06 04:07:13 +03:00
< hr / >
<!-- - Loops - -->
2015-10-07 23:54:19 +03:00
< h1 > Loops< / h1 >
< h2 > For Loop< / h2 >
2015-10-06 04:07:13 +03:00
< cfloop from = "0" to = "10" index = "i" >
2015-10-07 23:54:19 +03:00
< p > Index equals < cfoutput > #i#< / cfoutput > < / p >
< / cfloop >
< h2 > For Each Loop (Complex Variables)< / h2 >
< p > Set < b > myArray3< / b > to [5, 15, 99, 45, 100]< / p >
< cfset myArray3 = [5, 15 , 99 , 45 , 100 ] / >
< cfloop array = "#myArray3#" index = "i" >
< p > Index equals < cfoutput > #i#< / cfoutput > < / p >
< / cfloop >
< p > Set < b > myArray4< / b > to ["Alpha", "Bravo", "Charlie", "Delta", "Echo"]< / p >
< cfset myArray4 = ["Alpha", " Bravo " , " Charlie " , " Delta " , " Echo " ] / >
< cfloop array = "#myArray4#" index = "s" >
< p > Index equals < cfoutput > #s#< / cfoutput > < / p >
< / cfloop >
< h2 > Switch Statement< / h2 >
< p > Set < b > myArray5< / b > to [5, 15, 99, 45, 100]< / p >
< cfset myArray5 = [5, 15 , 99 , 45 , 100 ] / >
< cfloop array = "#myArray5#" index = "i" >
< cfswitch expression = "#i#" >
< cfcase value = "5,15,45" delimiters = "," >
< p > < cfoutput > #i#< / cfoutput > is a multiple of 5.< / p >
< / cfcase >
< cfcase value = "99" >
< p > < cfoutput > #i#< / cfoutput > is ninety-nine.< / p >
< / cfcase >
< cfdefaultcase >
< p > < cfoutput > #i#< / cfoutput > is not 5, 15, 45, or 99.< / p >
< / cfdefaultcase >
< / cfswitch >
2015-10-06 04:07:13 +03:00
< / cfloop >
< hr / >
2015-10-05 23:52:07 +03:00
2015-10-09 15:43:12 +03:00
< h1 > Converting types< / h1 >
2015-10-05 23:52:07 +03:00
2015-10-09 15:43:12 +03:00
< style >
table.table th, table.table td {
border: 1px solid #000000 ;
padding: 2px;
2015-10-05 23:52:07 +03:00
}
2015-10-09 15:43:12 +03:00
table.table th {
background-color: #CCCCCC ;
2015-10-05 23:52:07 +03:00
}
2015-10-09 15:43:12 +03:00
< / style >
< table class = "table" cellspacing = "0" >
< thead >
< tr >
< th > Value< / th >
< th > As Boolean< / th >
< th > As number< / th >
< th > As date-time< / th >
< th > As string< / th >
< / tr >
< / thead >
< tbody >
< tr >
< th > "Yes"< / th >
< td > TRUE< / td >
< td > 1< / td >
< td > Error< / td >
< td > "Yes"< / td >
< / tr >
< tr >
< th > "No"< / th >
< td > FALSE< / td >
< td > 0< / td >
< td > Error< / td >
< td > "No"< / td >
< / tr >
< tr >
< th > TRUE< / th >
< td > TRUE< / td >
< td > 1< / td >
< td > Error< / td >
< td > "Yes"< / td >
< / tr >
< tr >
< th > FALSE< / th >
< td > FALSE< / td >
< td > 0< / td >
< td > Error< / td >
< td > "No"< / td >
< / tr >
< tr >
< th > Number< / th >
< td > True if Number is not 0; False otherwise.< / td >
< td > Number< / td >
< td > See " Date-time values" earlier in this chapter.< / td >
< td > String representation of the number (for example, " 8" ).< / td >
< / tr >
< tr >
< th > String< / th >
< td > If "Yes", True < br > If "No", False < br > If it can be converted to 0, False < br > If it can be converted to any other number, True< / td >
< td > If it represents a number (for example, " 1,000" or " 12.36E-12" ), it is converted to the corresponding number.< / td >
< td > If it represents a date-time (see next column), it is converted to the numeric value of the corresponding date-time object. < br > If it is an ODBC date, time, or timestamp (for example " {ts ' 2001-06-14 11:30:13' }" , or if it is expressed in a standard U.S. date or time format, including the use of full or abbreviated month names, it is converted to the corresponding date-time value. < br > Days of the week or unusual punctuation result in an error. < br > Dashes, forward-slashes, and spaces are generally allowed.< / td >
< td > String< / td >
< / tr >
< tr >
< th > Date< / th >
< td > Error< / td >
< td > The numeric value of the date-time object.< / td >
< td > Date< / td >
< td > An ODBC timestamp.< / td >
< / tr >
< / tbody >
< / table >
2015-10-05 23:52:07 +03:00
2015-10-09 15:43:12 +03:00
< hr / >
2015-10-05 23:52:07 +03:00
2015-10-09 15:43:12 +03:00
< h1 > Components< / h1 >
< em > Code for reference (Functions must return something to support IE)< / em >
2017-01-01 02:36:08 +03:00
```
2024-04-06 18:33:50 +03:00
2017-01-01 02:36:08 +03:00
```cfs
2015-12-18 18:35:15 +03:00
< cfcomponent >
< cfset this . hello = "Hello" / >
< cfset this . world = "world" / >
< cffunction name = "sayHello" >
< cfreturn this . hello & " , " & this . world & " ! " / >
< / cffunction >
2015-10-09 15:43:12 +03:00
2015-12-18 18:35:15 +03:00
< cffunction name = "setHello" >
< cfargument name = "newHello" type = "string" required = "true" / >
2015-10-09 15:43:12 +03:00
2015-12-18 18:35:15 +03:00
< cfset this . hello = arguments.newHello / >
2015-10-09 15:43:12 +03:00
2015-12-18 18:35:15 +03:00
< cfreturn true / >
< / cffunction >
2015-10-09 15:43:12 +03:00
2015-12-18 18:35:15 +03:00
< cffunction name = "setWorld" >
< cfargument name = "newWorld" type = "string" required = "true" / >
2015-10-09 15:43:12 +03:00
2015-12-18 18:35:15 +03:00
< cfset this . world = arguments.newWorld / >
2015-10-09 15:43:12 +03:00
2015-12-18 18:35:15 +03:00
< cfreturn true / >
< / cffunction >
2015-10-09 15:43:12 +03:00
2015-12-18 18:35:15 +03:00
< cffunction name = "getHello" >
< cfreturn this . hello / >
< / cffunction >
2015-10-09 15:43:12 +03:00
2015-12-18 18:35:15 +03:00
< cffunction name = "getWorld" >
< cfreturn this . world / >
< / cffunction >
< / cfcomponent >
2015-10-09 15:43:12 +03:00
< cfset this . hello = "Hello" / >
< cfset this . world = "world" / >
< cffunction name = "sayHello" >
< cfreturn this . hello & " , " & this . world & " ! " / >
< / cffunction >
< cffunction name = "setHello" >
< cfargument name = "newHello" type = "string" required = "true" / >
< cfset this . hello = arguments.newHello / >
< cfreturn true / >
< / cffunction >
< cffunction name = "setWorld" >
< cfargument name = "newWorld" type = "string" required = "true" / >
< cfset this . world = arguments.newWorld / >
< cfreturn true / >
< / cffunction >
< cffunction name = "getHello" >
< cfreturn this . hello / >
< / cffunction >
< cffunction name = "getWorld" >
< cfreturn this . world / >
< / cffunction >
< b > sayHello()< / b >
< cfoutput > < p > #sayHello()#< / p > < / cfoutput >
< b > getHello()< / b >
< cfoutput > < p > #getHello()#< / p > < / cfoutput >
< b > getWorld()< / b >
< cfoutput > < p > #getWorld()#< / p > < / cfoutput >
< b > setHello("Hola")< / b >
< cfoutput > < p > #setHello("Hola")#< / p > < / cfoutput >
< b > setWorld("mundo")< / b >
< cfoutput > < p > #setWorld("mundo")#< / p > < / cfoutput >
< b > sayHello()< / b >
< cfoutput > < p > #sayHello()#< / p > < / cfoutput >
< b > getHello()< / b >
< cfoutput > < p > #getHello()#< / p > < / cfoutput >
< b > getWorld()< / b >
< cfoutput > < p > #getWorld()#< / p > < / cfoutput >
```
2015-10-05 23:52:07 +03:00
2015-10-31 03:15:06 +03:00
### CFScript
_**C**old**F**usion **S**cript_
In recent years, the ColdFusion language has added script syntax to mirror tag functionality. When using an up-to-date CF server, almost all functionality is available using scrypt syntax.
2015-10-05 23:52:07 +03:00
## Further Reading
The links provided here below are just to get an understanding of the topic, feel free to Google and find specific examples.
2015-10-09 15:43:12 +03:00
1. [Coldfusion Reference From Adobe ](https://helpx.adobe.com/coldfusion/cfml-reference/topics.html )
2015-10-31 03:15:06 +03:00
2. [Open Source Documentation ](http://cfdocs.org/ )