data:image/s3,"s3://crabby-images/e2286/e228693017ada212762f0b2d2043722958e79155" alt=""
Basic PowerFx Functions Every Developer Should Know
January 9, 2025
PowerFx is a declarative, Excel-like programming language, created by Microsoft, primarily for the creation of Canvas Apps. Like Excel, it uses functions and expressions to accomplish tasks with little to no need to specify step by step procedural logic. It abstracts away the implementation details, so the focus is on the ‘what’ and not the ‘how.’ This blog will highlight some of the basic PowerFx functions every developer should be familiar with.
Take the following table that lists the items and their cost in a ‘Shopping Cart’ for example.
ShoppingCart
ID | Item | $ Cost |
1 | Bread | 2 |
2 | Milk | 5 |
3 | Butter | 7 |
In an imperative language, the developer would have to loop through the records to calculate the sum of all the items in the shopping cart with code that resembles the following.
data:image/s3,"s3://crabby-images/593ab/593abbc147bbb4526461cddff6975f82f875cd8d" alt="Basic PowerFX Functions"
With PowerFx it is much more intuitive. With the following PowerFx, the expression also calculates the cost of all items in the ShoppingCart table, but without the imperative details.
data:image/s3,"s3://crabby-images/64b3a/64b3a7de83af4c0f0a940a9914806763a15e91cf" alt="Basic PowerFX Functions"
In this blog post, we will explore some important PowerFx functions— Filter, ClearCollect, With and Concurrent.
Power Fx Filter Function
ID | Name | Department |
1001 | Tom Smith | Sales |
1002 | Betty Johnson | Marketing |
1003 | Paul Alexander | Human Resources |
The Filter function is an essential part of creating expressions in Power Apps because it retrieves subsets of data from a larger dataset based on set criteria. When unnecessary data is filtered out from the dataset, the performance of the app improves commensurately because it has less records to process.
For example, if a list (EmployeeData) contains the personal data of all the employees in an organization and you want to display only the employees from the “Marketing” Department, this can easily be accomplished by using the following, Filter (EmployeeData, Department = “Marketing”)
Power Fx ClearCollect Function
A collection is a group of related items, such as products in a product list for example. Collections are one of the ways Power Apps stores data locally. The ClearCollect function deletes all records from the collection (if it is an existing collection), and then adds a separate set of records to the same collection or creates a new collection if it did not exist previously. By utilizing local collections, developers can optimize app performance, work offline, and streamline complex operations.
Using the previous example, if the EmployeeData list has hundreds of records you need to work with, instead of directly querying SharePoint each time you need to reference the data, you can use ‘ClearCollect’ to create a local copy of the data, making the app faster and more efficient. The example below creates a local copy of all the employees in the ‘EmployeeData’ list from the Marketing department.
ClearCollect (localEmployeeData, Filter (EmployeeData, Department = “Marketing”))
With Function
When writing complex expressions in Power Apps, ensuring the expression remains readable and easy to maintain can be challenging. The With function helps with this by simplifying expressions. In the following example we use a nested With function to calculate the area of a cylinder. In the example we separate height and radius values as well as the area of a circle calculation functions to make the final calculation (areaOfcircle * height), more readable.
data:image/s3,"s3://crabby-images/fce65/fce6507b37964339784a8968eb5d4f2ddc64ed49" alt="Basic PowerFX Functions"
Power Fx Concurrent Function
As the name suggests, the Concurrent function allows the user to evaluate several functions concurrently, not sequentially, provided they are not dependent on each other. The obvious benefit is faster processing. One of the places Concurrent is most useful is in the App, OnStart property. The OnStart property is where configuration details are typically placed and is ran when the app loads. The following collections are created concurrently.
data:image/s3,"s3://crabby-images/a589f/a589f50ef19d1961122abbef102f01dca6136281" alt=""
Leveraging Concurrent is particularly beneficial when dealing with multiple, independent tasks within your app.
There are many more useful functions to take advantage of with PowerFx. Hopefully this gives you a good start. For more information on PowerFx functions please visit the Microsoft Learn PowerFx overview page at Microsoft Power Fx overview – Power Platform | Microsoft Learn
If you have another project in mind, fill out the form at the bottom of the page and someone will be in touch with you. And thanks for reading! Make sure to subscribe to our blog. We publish technology tips, tricks, and updates every week.
Want to hear the latest from out team of experts? Sign up to receive the latest news right to your inbox. You may unsubscribe at anytime.
data:image/s3,"s3://crabby-images/a47b1/a47b149ad759da9d3a10a27f702e75570f735f0b" alt="Teams Premium"
Discover More
Load SharePoint Items into Power Apps Without Delegation Limitations
Load SharePoint Items into Power Apps Without Delegation Limitations February 13, 2025 Loading large datasets into Power Apps galleries or data tables can be a significant challenge in app development,…
Top 3 Beginner Tips for Developing Canvas Power Apps
Top 3 Beginner Tips for Developing Canvas Power Apps February 13, 2025 Canvas Power Apps is a handy tool from Microsoft that lets you build custom business apps without needing…
Clean Data, Clear Decisions: How to Optimize Data Quality
Clean Data, Clear Decisions: How to Optimize Data Quality February 6, 2025 Last week, I sat down with one of our data experts, Olena Shevchenko, to get her thoughts on…
data:image/s3,"s3://crabby-images/1047f/1047f4895708bfe6a35341ba1d75ef025be8c1ee" alt=""
Let’s build something amazing together
From concept to handoff, we’d love to learn more about what you are working on.
Send us a message below or call us at 1-800-989-6022.