Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

The CFC Object Model


 

Table of Contents

The CFC Object Model

The CFML programming language provides object-oriented programming facilities by way of CF Components, commonly referred to as CFCs. Each CFC is conceptually similar to a class in other OO languages, which means that a CFC encapsulates both data and code. Data members of CFCs are referred to as properties, while the code to interact with those properties are methods. All CFC methods are actually functions (similar to extrinsic functions in MUMPS) which gain the benefits of the properties exposed in their containing CFC. In the case of CFMumps, each API is a CFC whose properties define and maintain the state of the MUMPS database connection, and whose methods are the APIs against which your applications will be developed, such as get()set()kill()data(), and order().

You can think of each CFC as a complex, high-level data type that just happens to also contain code that you can run.

In order to gain access to the methods and properties of the CFCs which implement the CFMumps API, you need to create an instance of the appropriate CFC. An instance is simply a variable through which you access the methods and properties of the API you wish to use. Creating an instance is accomplished with the createObject() CFML/CFScript function.

Here is an example–expressed in both CFScript and tag-based CFML--creating an instance of the basic API:

Code Block
languagejs
titleCFScript
var myCFCInstance = createObject("component", "lib.cfmumps.mumps");
Code Block
languagecoldfusion
titleCFML
<cfset var myCFCInstance = createObject("component", "lib.cfmumps.mumps")>

Each of the above code snippets will produce identical results: the variable myCFCInstance is created and initialized as an instance of lib.cfmumps.mumps, which is the component that implements the CFMumps basic API. Its methods are available by appending a dot to the variable name myCFCInstance, followed by the name of the method you wish to call, as follows:

Code Block
languagejs
titleCFScript
myCFCInstance.open();
Code Block
languagecoldfusion
titleCFML
<cfset myCFCInstance.open()>

The above examples open the database for the myCFCInstance instance of the lib.cfmumps.mumps CFC.