Aura components are self-contained and reusable building blocks for creating web applications on the Salesforce platform. In larger applications, components often need to communicate with one another.

In this blog, we’ll explore the different types of communication that can occur between two Aura components.

Types of Communication between Aura Components

There are two types of communication in Aura components.

    1. Component Events
    2.  Application Events

Component events are best used for communicating between closely related components, while Application events are best used for triggering actions that affect multiple components.

By understanding the differences between these two types of communication, you can choose the right method for your specific use case and build more efficient and modular applications.

Let’s explore them in detail!

1. Component Events

Aura Components provide a variety of ways for components to communicate with each other, including Component Events. Component events allow components to communicate with other components that may not be in a direct parent-child relationship.

In this article, we will explore how to use component events in both parent-to-child and child-to-parent communication scenarios.

Here is an example of how component events can be used to communicate between two Aura components:

Two ways of communication in Component Events.

1. Call Child Component through Parent Component:

2. Call Parent Component method from Child Component:

2. Application Events

Application events are used to communicate between components that are not closely related to each other. They allow for decoupling between components and can be used to trigger actions that affect multiple components.

Unlike component events, application events follow a publish-subscribe pattern, where an event is fired and any component that is listening for that event can receive it.

To create an application event, you need to define the event in a separate .evt file. Here’s an example:

To publish an application event, you use the $A.get()method to get a reference to the event and then call the fire()method to publish it. Here’s an example:

To subscribe to an application event, we use the <aura:handler>tag in our component markup. Here’s an example:To subscribe to an application event, we use the <aura:handler>tag in our component markup. Here’s an example:

In this example, we define a component called **MyComponent**and use the <aura:handler> tag to subscribe to the **myEvent**event that we defined earlier. We specify the **event**attribute as “c:myEvent” to indicate that we want to subscribe to the **myEvent**event in the “c” namespace. We also specify the **action**attribute to indicate the JavaScript function that should be called when the event is fired.

Handling an Application Event:

When an application event is fired, the JavaScript function specified in the **action**attribute of the **<aura:handler>**tag is called with an **event**parameter. Here’s an example:

In this example, we define a JavaScript controller for **MyComponent**and create a function called **handleEvent**that takes the component, event, and helper parameters. We use the **getParam()**method on the **event**parameter to retrieve the value of the “message” attribute that was set when the event was fired. We then log the message to the console.

Conclusion

That wraps our today’s coverage of communication between the two aura components.

Go ahead and try out the solution to find how these events can be used to communicate with two aura components.

And, if you like liked this article, share your thoughts and follow us for more!

Related Articles
Expert Guide On Nominal XIRR Calculation Using LWC in Salesforce

When building financial tools within Salesforce, handling irregular cash flows with precision is a must. Whether you’re developing investment trackers, portfolio performance dashboards, or funding monitors, calculating Nominal XIRR (Extended Internal Rate of Return) becomes essential. In this blog, you’ll learn how to build a Lightning Web Component (LWC) in Salesforce that calculates Nominal XIRR […]

Read More
Beginners Guide to Making Your LWC Component Multilingual

If you’re wondering how to make your LWC component multilingual, you’re already ahead of the curve. Global users expect content in their native language, and Salesforce gives you the tools to deliver exactly that. With Custom Labels and the Translation Workbench, you can easily localize your Lightning Web Components without touching a single line of […]

Read More
Hands-On Guide Building a Drag-and-Drop Form Builder Using Lightning Web Components

Drag-and-drop interfaces are a user experience staple, and when paired with the power of Lightning Web Components (LWC), they unlock dynamic, highly interactive Salesforce components. In this blog post, we’ll walk you through how to build a custom drag-and-drop form builder in LWC. Users can drag form fields like text inputs and dropdowns into a […]

Read More
Please Make Blog Banner How to Create an Agentforce Enabled Scratch Org in Salesforce 100 1

Setting up an Agentforce-enabled scratch org is the most important step for developers who want to experiment with AI features such as Prompt Builder and Einstein GPT. Whether you’re developing the next generation CRM software or experimenting with how generative AI may improve user experience, a scratch org equipped with Agentforce is your playground. Follow […]

Read More
Step-by-Step Guide to Enhance Your LWC Development Workflow with the Logger API

Are you looking to streamline your LWC development workflow but confused about how to do it? Then you are in the right place. The Salesforce Logger API is a powerful tool that helps you monitor, debug, and improve code quality in real time.  This step-by-step guide walks you through how to set it up and […]

Read More
Enhancing Your Salesforce Experience with a Custom Activity Component

In today’s fast-paced business landscape, productivity hinges on streamlined workflows and intuitive interfaces. While Salesforce offers robust activity tracking capabilities, sometimes the standard components fall short of specific organizational needs.  That’s where a Custom Activity Component comes in—designed to tailor your activity management experience, boost user efficiency, and provide deeper insights into customer interactions. In […]

Read More
Our Location worldwide
Indian Flag India
3rd Floor, A-10, Pegasus Tower, Sector 68, Noida, Uttar Pradesh 201301 +91-1203117884
United States of America Flag USA
333 West Brown Deer Road Unit G – 366 Milwaukee WI, USA 53217 +1(262) 310-7818
United Kingdom Flag UK
7 Bell Yard, London, WC2A 2JR +44 20 3239 9428
Canada Canada
HIC Global Solutions INC
43 Lafferty Lane, Richmond Hill, L4C 3N8, CA +1(262) 310-7818