How to capture reference of another component in Blazor App

This blog post will show you how to reference components in another component. To make the demo simple, I have created a simple contact list. Then from the parent page, I am referring to the contact list and invoking the show/hide method of the contact list.

BlazorApp/Models/Contact.cs

namespace BlazorApp.Models
{
    public class Contact
    {

        public string Name { get; set; }
        public string Email { get; set; }
        
    }
}

Create a razor component named ContactList and paste the following code

BlazorApp/Page/ContactList.razor

@using Models

<h4>Contact List</h4>
<table hidden="@showContacts">
    <thead>
        <th>Name</th>
        <th>Email</th>
    </thead>
    <tbody>
        @foreach (var item in contacts!)

        {
            <tr>
                <td>@item.Name</td>
                <td>@item.Email</td>
            </tr>



        }
    </tbody>
</table>


@code {


    private bool showContacts = true;
    private List<Contact>? contacts = null;
    protected override void OnInitialized()
    {
        contacts = new List<Contact>(){
        new Contact(){Name="John ",Email="john@example.com"},
        new Contact(){Name="Bob",Email="bob@example.com"},
        new Contact(){Name="Bill",Email="bill@example.com"}
};

        base.OnInitialized();

    }
    public void ShowContacts(){
        showContacts=true;
        StateHasChanged();
    }
   public void HideContacts(){
        showContacts=false;
        StateHasChanged();
    }

}

The above component shows the contact list and has two public methods, ShowContacts and HideContactsWhich we will trigger from the Parent component.

Now in Index.razor page paste the following code

BlazorApp/Page/Index.razor

@page "/"

<PageTitle>Index</PageTitle>

<ContactList @ref="contactListRef" ></ContactList>
<button  @onclick="ShowHide">Show/Hide</button>

@code{
    private bool isContactVisisble=true;
    private ContactList contactListRef;

    public void ShowHide(){
        isContactVisisble=!isContactVisisble;
        if(!isContactVisisble){
            contactListRef.HideContacts();
        }else{
            contactListRef.ShowContacts();
            
        }
    }
}

In the above code, I have declared a private variable contactListRef

private ContactList contactListRef;

and then I have assigned it to the @ref attribute

<ContactList @ref="contactListRef" ></ContactList>

What is @ref

As per the MSDN. Component references provide a way to reference a component instance for issuing commands. To capture a component reference:

  • Add an @ref attribute to the child component.
  • Define a field with the same type as the child component.
  • The field is populated with the component instance when the component is rendered. You can then invoke .NET methods on the instance.

index.razor the page has one button; on the click of a button, I am invoking the reference component method, which shows and hides the component

public void ShowHide(){
        isContactVisisble=!isContactVisisble;
        if(!isContactVisisble){
            contactListRef.HideContacts();
        }else{
            contactListRef.ShowContacts();
            
        }
    }
Next Post Previous Post
No Comment
Add Comment
comment url