How do I access child components in lightning input in the DOM element?

990    Asked by DavidPiper in Salesforce , Asked on Feb 8, 2023

 I am trying to populate the field that is nested within an aura component using DOM elements.


I am able to access the parent with document.getElementsByTagName; however, I cannot access the child component that is nested in the parent lightning-input. After looking into the documentation, it mentions that we cannot use document or window properties to query these nested DOM elements, but instead, we need to use the template as the root target.


Reference

https://developer.salesforce.com/docs/component-library/documentation/en/lwc/lwc.create_components_dom_work


Is it possible to view the nested input tags and modify the text within it?


Example Format


    
        <input id="input-0">
    

For more context, the input tag acts as a login field, where I am looking to populate the field when a button is pressed externally (within a mobile app).


You can't nest input fields, either in LWC or even normal HTML. The reason why this doesn't work is because lightning input doesn't have a default slot. Even getting the input element wouldn't set the lightning-input value, as that's a separate input field.


All that said, you can just set the value directly:

handleClick(event) {
  this.template.querySelector('lightning-input').value = 'Hello World!';
}
You can give the element some unique attribute if you need to retrieve it amongst several such fields on the page, such as:

...
const input = this.template.querySelector('lightning-input[name=username]');
input.value = 'Hello World!';


Your Answer

Answer (1)

Accessing child components within a Lightning Web Component (LWC) can be done using the querySelector or querySelectorAll methods. These methods allow you to traverse the DOM and access child elements of a particular component.

Steps to Access Child Components in LWC

  • Assign a CSS class or ID to the child elements you want to access.
  • Use JavaScript to query the DOM for these elements.

Example Scenario

Let's say you have a parent LWC (parentComponent) that contains several lightning-input elements as children. You want to access these lightning-input elements in the DOM.

Step 1: Define the Child Components in HTML

In your parentComponent.html, define the child lightning-input elements and assign them a CSS class or ID for easy querying.


   

       

           

           

           

       

       

   

Step 2: Query the DOM in JavaScript

In your parentComponent.js, use the querySelectorAll method to access the lightning-input elements and interact with them.

import { LightningElement, track } from 'lwc';
export default class ParentComponent extends LightningElement {
    @track inputValue1;
    @track inputValue2;
    @track inputValue3;
    handleGetValues() {
        // Query all elements with the class 'child-input'
        const inputs = this.template.querySelectorAll('.child-input');
        // Iterate over the NodeList and log the value of each input
        inputs.forEach(input => {
            console.log(input.value);
        });
    }
}

Explanation

1. HTML Template:

  • The lightning-input elements are given a class of child-input.
  • A button is added that triggers the handleGetValues method when clicked.

2. JavaScript Controller:

  • The handleGetValues method uses this.template.querySelectorAll('.child-input') to get a NodeList of all elements with the class child-input.
  • The forEach method iterates over the NodeList, and input.value accesses the value of each lightning-input.

3. Accessing Specific Inputs

If you need to access a specific lightning-input, you can use querySelector with an ID or a more specific selector.


   

       

           

           

           

       

       

   

handleGetInput2Value() {
    // Query the element with the ID 'input2'
    const input2 = this.template.querySelector('#input2');
    if (input2) {
        console.log(input2.value);
    }
}

Conclusion

By assigning CSS classes or IDs to your child elements and using the querySelector or querySelectorAll methods, you can easily access and interact with child components in LWC. This approach allows you to manipulate and retrieve values from child components, facilitating dynamic interactions within your Lightning Web Components.


7 Months

Interviews

Parent Categories