# Computed Properties

Computed Properties are dynamic properties and are helpful for deriving values from a database or another persistent store like a cache.&#x20;

Computed Properties are similar to [Data Properties](/3.x/essentials/properties.md) with some key differences:

* They are declared as inline functions using **computed***.*
* They can return any CFML data type, not just values that can be parsed by JavaScript like [Data Properties](/3.x/essentials/properties.md).

## Defining Properties

You can define Computed Properties on your components using **computed**.&#x20;

```html
<cfscript>
    computed = {
        "tasks": function() {
            return queryExecute( "
                select *
                from tasks
            " );
        }
    };
</cfscript>
```

## Accessing Properties

You can access Computed Properties in your component template using **propertyName()**.

```html
<cfscript>
    computed = {
        "currentTime": function() {
            return now();
        }
    };
</cfscript>

<cfoutput>
    <div>
        Current time: #currentTime()#
    </div>
</cfoutput>
```

You can also access Computed Properties from within your [Actions](#actions).

```html
<cfscript>
    computed = {
        "currentTime" : function() {
            return now();
        }
    };    
    
    function sendEmail() {
        if ( dateDiff( "d", computed.currentTime() ) > 3 ) {

        }
    }
</cfscript>
```

{% hint style="info" %}
Computed Properties are defined as a CFML closure. That means that to get the result from the function, you must invoke it like so.

```javascript
myComputedProperty() // good
```

```
myComputedProperty // bad
```

{% endhint %}

## Caching

**Computed Properties are cached for the lifetime of the request.** If you reference your Computed Property three times in your component template or from within a component action, it will only execute once.

```html
<cfscript>
    computed = {
        "getUUID": function() {
            return createUUID();
        }
    }
</cfscript>

<cfoutput>
    <div>
        <p>#getUUID()#</p>
        <p>#getUUID()#</p> <!-- Outputs the same ID because of caching -->
    </div>
</cfoutput>
```

You can prevent caching on a computed property by passing a false argument when invoking it.

```html
<p>#getUUID()#</p>
<p>#getUUID( false )#</p> <!-- Does not use caching --->
```


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://cbwire.ortusbooks.com/3.x/essentials/computed-properties.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
