Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Free Learning
Arrow right icon
Arrow up icon
GO TO TOP
Blazor Web Development Cookbook

You're reading from   Blazor Web Development Cookbook Tested recipes for advanced single-page application scenarios in .NET 9

Arrow left icon
Product type Paperback
Published in Nov 2024
Publisher Packt
ISBN-13 9781835460788
Length 282 pages
Edition 1st Edition
Languages
Tools
Arrow right icon
Author (1):
Arrow left icon
Pawel Bazyluk Pawel Bazyluk
Author Profile Icon Pawel Bazyluk
Pawel Bazyluk
Arrow right icon
View More author details
Toc

Table of Contents (13) Chapters Close

Preface 1. Chapter 1: Working with Component-Based Architecture 2. Chapter 2: Synchronous and Asynchronous Data Binding FREE CHAPTER 3. Chapter 3: Taking Control of Event Handling 4. Chapter 4: Enhancing Data Display with Grids 5. Chapter 5: Managing Application State 6. Chapter 6: Building Interactive Forms 7. Chapter 7: Validating User Input Forms 8. Chapter 8: Keeping the Application Secure 9. Chapter 9: Exploring Navigation and Routing 10. Chapter 10: Integrating with OpenAI 11. Index 12. Other Books You May Enjoy

Creating components with customizable content

Creating components with customizable content in Blazor applications is another level in building flexible and reusable UI elements. This approach allows you to design functional components that can be adapted to various content needs and data types. We’ll utilize the RenderFragment feature to address it. The RenderFragment feature represents a segment of UI content. It allows components to accept arbitrary HTML markup as a parameter. That’s how you can achieve higher flexibility. You can repurpose a single component structure with different content, enhancing the modularity and reusability of your code base.

Let’s create a Ticket component with a customizable display of ticket details while keeping a fixed button so that you can add the ticket to a cart.

Getting ready

Before you start implementing a component with customizable content, do the following:

  • Create a Recipe07 directory – this will be your working directory
  • Copy the Chapter01/Data directory, which contains the Samples and TicketViewModel objects required for this recipe, next to the working directory

How to do it...

Follow these steps to build a component with customizable content:

  1. Create a new Ticket component. We’ll use this to display individual ticket details.
  2. In the @code block of Ticket, add the Id and ChildContent parameters and an Add() placeholder method that simply writes a console message displaying the ID of the ticket that was added to the cart:
    @code {
        [Parameter, EditorRequired]
        public Guid Id { get; set; }
        [Parameter, EditorRequired]
        public RenderFragment ChildContent { get; set; }
        public void Add()
            => Console.WriteLine($"Ticket {Id} added!");
    }
  3. As the Ticket markup, render the ChildContent value and a button to trigger the Add() method:
    <div class="ticket">
        <div class="ticket-info">@ChildContent</div>
        <div class="ticket-actions">
            <button @onclick="@Add">Add to cart</button>
        </div>
    </div>
  4. Create a routable Offer component that renders in InteractiveWebAssembly mode. Add a @using directive so that the Samples object can be referenced:
    @page "/ch01r07"
    @using
        BlazorCookbook.App.Client.Chapters.Chapter01.Data
    @rendermode InteractiveWebAssembly
  5. As markup of the Offer component, while leveraging the Ticket component, render a Samples.Adult ticket tariff and price and a Samples.FreeAdmission ticket with just a tariff name since it’s free to do so:
    <Ticket Id="@Samples.Adult.Id">
        @Samples.Adult.Tariff (@Samples.Adult.Price)
    </Ticket>
    <Ticket Id="@Samples.FreeAdmission.Id">
        <div class="free-ticket">
            @Samples.FreeAdmission.Tariff
        </div>
    </Ticket>

How it works...

In step 1, we created a new Ticket component and implemented its @code block in step 2. Then, we declared a set of required parameters – Id to add a ticket to the cart and ChildContent, which is of the RenderFragment type, to hold the custom markup for a Ticket instance. We leveraged the EditorRequired attribute and made both parameters required. In step 3, we implemented the Ticket markup. We embedded the ChildContent value to render ticket details by placing it the same as any other parameter. We also added a button that allows the user to add a ticket to the cart by leveraging the Add() method.

In step 4, we created an Offer component. We utilized the @page directive to make it routable and declared it so that it rendered in the InteractiveWebAssembly mode. On top of that, we added a @using directive with the namespace of the Samples object so that we could reference it within the Offer component (the namespace can vary depending on the structure and name of your solution). In step 5, we implemented the Offer markup and saw the RenderFragment object in action. For an adult ticket with a price tag, we rendered both its tariff and price. For the free admission ticket, we chose to render only the tariff name. Blazor will inject the custom markup in place of the ChildContent parameter, within the Ticket component, while retaining and reusing the interactive button implementation, regardless of the customized content.

There’s more...

You can use a RenderFragment object to encapsulate common parts of your components. The testing and maintainability of your code will skyrocket. Another reason to leverage them is that a static RenderFragment instance positively impacts performance.

You might have noticed that when a RenderFragment parameter is named ChildContent, the compiler automatically recognizes and assigns its value. You can still opt to declare <ChildContent> </ChildContent> explicitly but there’s no need to complicate your code.

However, you might encounter scenarios where you need more than one customizable section within a component. Fortunately, Blazor allows you to have multiple RenderFragment parameters. To implement that, you must explicitly declare both RenderFragment values using markup element syntax within your component. This approach enables even higher modularity and adaptability of your UI. For instance, you could have Details and Actions content to structure your component with multiple customizable areas. You can see that in the following code blocks.

Here’s the Ticket component, which allows us to customize the Details and Actions areas:

<div class="ticket">
    <div class="ticket-info">@Details</div>
    <div class="ticket-actions">@Actions</div>
</div>
@code {
    [Parameter, EditorRequired]
    public RenderFragment Details { get; set; }
    [Parameter, EditorRequired]
    public RenderFragment Actions { get; set; }
}

Here’s the Ticket component in action, with customized Details and Actions areas:

<Ticket>
    <Details>
        @Samples.Adult.Tariff (@Samples.Adult.Price)
    </Details>
    <Actions>
        <button @onclick="@(() => Add(Samples.Adult.Id))">
            Add to cart
        </button>
    </Actions>
</Ticket>
lock icon The rest of the chapter is locked
Register for a free Packt account to unlock a world of extra content!
A free Packt account unlocks extra newsletters, articles, discounted offers, and much more. Start advancing your knowledge today.
Unlock this book and the full library FREE for 7 days
Get unlimited access to 7000+ expert-authored eBooks and videos courses covering every tech area you can think of
Renews at $19.99/month. Cancel anytime
Banner background image