Earn a Salesforce AI Certification by E&ICTA, IIT Kanpur + 12-Week Internship Secure Your Spot Today!

Earn a Salesforce AI Certification by E&ICTA, IIT Kanpur + 12-Week Internship Secure Your Spot Today!
Custom Label in Lightning Web Component (LWC)

Custom Label in Lightning Web Component (LWC) | saasguru

Custom labels in Salesforce Lightning Web Components (LWC) are user-defined text values accessed from any Apex or LWC code. They are critical in application development, especially in scenarios requiring localization, dynamic text values, and maintainability.

One of the key advantages of custom labels is their ability to promote consistency and ease of updates. Since the text is stored in a centralized location, changes to the label automatically propagate throughout the application, eliminating the need to search and replace text in multiple places.

In this blog, you will learn:

  • What Custom labels is
  • Importance of Custom labels in LWC
  • Creating custom labels in LWC with example
  • Advanced Use Cases

Custom Labels In Lightning Web Component(LWC) Example

Step 1: Create Custom Labels in Salesforce

First, you need to create the custom labels in Salesforce.

  1. Navigate to Setup in your Salesforce org.
  2. Go to Custom Labels (found under User Interface or Customize in Setup).
  3. Create two new labels:
  • Label Name: GreetingMessage, Value: “Hello, Welcome to our site!”
  • Label Name: FarewellMessage, Value: “Thank you for visiting, goodbye!”

Step 2: Create the LWC

Now, let’s create the Lightning Web Component.

File: exampleComponent.js

import { LightningElement } from ‘lwc’;

import greetingMessage from ‘@salesforce/label/c.GreetingMessage’;

import farewellMessage from ‘@salesforce/label/c.FarewellMessage’;

export default class ExampleComponent extends LightningElement {

    // Properties to hold the label values

    greeting = greeting message;

    farewell = farewellMessage;

}

In the JavaScript file, we import the custom labels and assign them to component properties using the import statement.

File: exampleComponent.html

<template>

    <div>

        <p>{greeting}</p> <!– Displaying the greeting message –>

        <p>{farewell}</p> <!– Displaying the farewell message –>

    </div>

</template>

In the HTML template, we use the properties to display the label values.

Step 3: Deploy and Test

After creating the component, you would deploy it to your Salesforce org and add it to a page to test it. The component will display the greeting and farewell messages defined in the custom labels.

Also Read – Combobox in LWCsaasguru Salesforce Labs: Real-time Projects for Practice

Advanced Use Cases

Dynamic Language Switching

Dynamic language switching allows your LWC to adapt its displayed labels according to the user’s language preference, enhancing the user experience for a global audience

How to Implement:

  • Set Up Translated Labels: In Salesforce, provide translations for your custom labels for all supported languages.
  • User Language Preference: Salesforce automatically uses the user’s language setting to display the correct label translation.
  • Component Implementation: When you use a custom label in your LWC, Salesforce handles the translation dynamically based on the user’s language setting. There’s no additional coding required for this basic functionality.

Example:

If you have a custom label named GreetingMessage, translated into multiple languages in the Salesforce setup, Salesforce will automatically display the appropriate translation in your LWC based on the user’s language preference.

Incorporating Variables in Labels

Sometimes, you need to display dynamic content within a label (like a user name, date, or any other variable data). Salesforce does not directly support variables in custom labels, but you can achieve this by combining labels with JavaScript string manipulation.

How to Implement:

  • Create Custom Labels with Placeholders: For example, a label with Welcome, {0}! Today is {1}.
  • Replace Placeholders in JavaScript: In your LWC’s JavaScript file, use string replacement to substitute placeholders with dynamic values.

Example Code:

JavaScript File (exampleComponent.js):

import { LightningElement } from ‘lwc’;

import baseLabel from ‘@salesforce/label/c.WelcomeMessage’;

export default class ExampleComponent extends LightningElement {

    get welcomeMessage() {

        const userName = ‘John Doe’; // Dynamic value, e.g., fetched from user data

        const todayDate = new Date().toLocaleDateString();

        return baseLabel.replace(‘{0}’, userName).replace(‘{1}’, todayDate);

    }

}

HTML Template (exampleComponent.html):

<template>

    <p>{welcomeMessage}</p>

</template>

Also Read – Salesforce LWC Datatable – Go-To Guide

Importance of Custom Labels in LWC

  • Localization and Internationalization: In today’s global market, applications need to cater to users from various regions, each with their own language preferences. Custom labels in LWC make translating text into different languages simpler without altering the code. This feature mainly benefits multinational companies looking to localize their applications for different markets.
  • Reusability and Maintenance: Custom labels enhance code reusability and ease maintenance. When developers need to update any text, they can do so in one place rather than modifying it in multiple components. This centralized approach to managing text reduces errors and saves development time.
  • Dynamic Content Delivery: Custom labels can be used to deliver dynamic content based on user preferences, roles, or any other criteria defined in Salesforce. This flexibility allows for a more personalized user experience.
  • Avoiding Hard-Coded Text: Hard-coding text directly into components is not a best practice, as it makes localization and updates cumbersome. Custom labels provide a more scalable and manageable approach, keeping the UI text separate from the component logic.
  • Enhanced Collaboration and Consistency: Since custom labels are centralized, they promote consistency across different components and pages of the application. They also make it easier for teams to collaborate, as developers and translators can work on the labels independently of the component development.Online Bootcamps India

Common Pitfalls and Best Practices for Using Custom Labels in LWC

Common Pitfalls

1. Overloading Custom Labels:

Using custom labels for purposes other than static text, such as storing dynamic or frequently changing data, can lead to maintenance headaches.

Tip: Use custom labels only for static or semi-static text values. For dynamic data, rely on Apex methods or Lightning Data Services.

2. Ignoring Translations:

Many developers overlook the importance of translations, especially for global applications, resulting in a poor user experience for non-English users.

Tip: Always provide translations for your custom labels in all supported languages to ensure a seamless experience for your global audience.

3. Hardcoding Labels in JavaScript:

Hardcoding label values in JavaScript defeats the purpose of custom labels and makes localization difficult.

Tip: Always use the @salesforce/label import to reference custom labels.

4. Performance Impacts with Excessive Imports:

Importing too many custom labels can lead to larger component bundles, affecting performance.

Tip: Group related labels into fewer imports and avoid overusing custom labels for trivial text.

Best Practices

1. Plan for Reusability:

Design custom labels with reusability in mind. Generic labels like Submit, Cancel, or ErrorMessage can be shared across multiple components.

Example: Use a single ErrorMessage label for error popups across your application.

2. Use Descriptive Names:

Give custom labels meaningful and descriptive names that clearly indicate their purpose.

Example: Instead of Label1, use InvalidLoginMessage.

3. Combine with Dynamic Content:

Combine custom labels with variables to create dynamic messages without creating multiple labels for similar use cases.

Example: A single label like Hello, {0}! Welcome back. can be used with dynamic content for personalized greetings.

4. Organize Labels by Functionality:

Categorize labels based on their purpose, such as ErrorMessages, SuccessMessages, or UIComponents, to make management easier.

Tip: Use naming conventions like UI_LoginButtonLabel or Error_InvalidCredentials for clarity.

5. Test Labels Across Languages:

Test your application with different user language settings to ensure translations display correctly.

Tip: Use Salesforce’s Translation Workbench to manage and verify label translations.

6. Document Your Labels:

Maintain documentation for your custom labels, including their purpose and any placeholders used. This helps in future updates and makes it easier for new developers to understand the application.

Conclusion

A custom label is a key-value pair. The key is the label’s unique name, and the value is the text or message it holds. This value can be translated into multiple languages supported by Salesforce, enabling the creation of multilingual applications. Custom labels can store strings like error messages, form labels, or any other text that might need to be displayed in a Salesforce application.

If you’re eager to deepen your Salesforce skills and connect with a community of like-minded professionals, consider joining our community on Slack. Here, you’ll find a wealth of knowledge, support, and networking opportunities. 

Additionally, saasguru offers hands-on online Salesforce bootcamps, where you can gain practical experience and work on real projects. These bootcamps are designed to provide you with the skills and confidence needed to excel in your Salesforce career.

Whether you’re a beginner or looking to advance your skills, our community and bootcamps are here to support your journey. 

Connect with saasguru today and start transforming your Salesforce expertise!

Table of Contents

Subscribe & Get Closer to Your Salesforce Dream Career!

Get tips from accomplished Salesforce professionals delivered directly to your inbox.

Looking for Career Upgrade?

Book a free counselling session with our Course Advisor.

By providing your contact details, you agree to our Terms of use & Privacy Policy

Unlock Your AI -Powered Assistant

Gain Exclusive Access to Your Salesforce Copilot

Related Articles

Is Salesforce Agentforce Replacing Einstein Copilot?

Salesforce rebrands Einstein Copilot as Agentforce, embracing autonomous AI agents to redefine business efficiency and innovation. Read now!

What Are Agentic AI Workflows?

Discover what agentic AI workflows are, their benefits, applications, and how they redefine automation with adaptive, autonomous AI agents.

Understanding Agentic AI Planning Patterns

Discover Agentic AI Planning Patterns: Learn how AI breaks down complex tasks into steps, adapts dynamically, and achieves goals efficiently.