Skip to main content

Using closures to make structs behave like objects

When they added closures and anonymous functions to Coldfusion in version 10 it opened up a lot of interesting new avenues to explore.  Some of these are very useful.  Anonymous functions can be created and passed as arguments to other functions without having to separately create a named function.  They added callback arguments to some of the array functions and various others.

Closures allow us to access variables that exist when the function is created, in the same way we do in javascript.  With that ability we can do some very interesting things with structs.



The example above shows how we can create a struct with a function that updates one of the other keys in the struct.  This is very much like an object with properties and methods.  Inside a function we create a var'ed struct named this.  I used the name "this" for the struct, but that name has no special significance here.  I added the value property and a method to set the value.  When we run that code we get the following output.


You can see the struct with the initial value of 5.  Then after the call to setValue it has changed to 10.  Then I dumped out the variables scope just to show that nothing odd is being set outside the struct.

This is interesting but I think we can go further with this idea.  What if we want our object to have private properties.



The code in this example var's the value property instead of adding it to the this struct.  Then I have added a getValue method.  This code produces the following output.



So you can see the value property is not exposed in the dumps of the struct, but we are able to access it and change it with the getValue and setValue methods.

Now we have demonstrated private and public properties, and we have public methods.  I think you can imagine how to create a private method by var'ing a variable and setting it equal to a function.  I wont demonstrate that.

That's all I have for now.  In a future article I may explore inheritance and some other object oriented topics.


Comments

Popular posts from this blog

Getting Hidden App Data From Your Google Drive

Some Android applications use space on your Google Drive to store data.  You can't see this data by browsing drive the normal way.  You can get access to it if you get the access token from the app and do a few other things.

I use an app to keep some notes and other things.  They require getting the paid version of the app to backup your data.  I wanted to see if I could get it myself without paying for the app.  I found out how to do this from this Stackoverflow post http://stackoverflow.com/questions/22832104/see-hidden-app-data-in-google-drive.  The example there uses php. Since I have been learning Python recently, I decided to see if I could do the same thing with Python.

 There is a pretty good explanation of why you need to go through all the steps you need to go through to get your data in the accepted answer for that post, so I won't go into too much detail about that here.


Using IR codes from Broadlink backup file

This is a continuation of yesterdays post about the Broadlink RM2 wifi remote.  I was able to test out using the codes to control my remote today.  They are stored in JSON format in the broadlink backup file.  The backup file is a zip file.  After you extract it there is a folder named SharedData.  There are several files in the folder.  The one that seems to have all the codes is named jsonIrCode.  The data looks like an array of objects, each with a code and some other information.


Setting Up an Angular 5 site on Github Pages

Getting Started

This article will go over all the steps to setup an Angular site on GitHub pages.  The site will use Angular's AOT compiling and be served from the docs folder of the repository.

To start with you can follow the guide here to setup a new Angular project. Then you will need to setup a repository on Github.com.  The name of the repository doesn't matter, this site will use the docs folder, not the specially named repository with USERNAME.github.io as the name.



Project Changes

After that open up the project in your editor and open the .angular.cli.json file.  Change the "outDir" to "docs".  This is where the files will be created when you build the project.  The contents of .angular.cli.json are shown below with all the changes discussed in the article.

Custom Domain

To use a custom domain for your site you need to create a file name CNAME that contains only the domain name.  The GitHub help page explains how to setup DNS and everything else you …