How to align labels and textboxes using Flexbox

Aligning labels and textboxes in a form can be a challenging task, especially when dealing with varying label lengths and input widths. However, with Flexbox, achieving a consistent and responsive layout becomes a breeze. In this tutorial, we’ll explore how to use Flexbox to align labels and textboxes in a Blazor form, but the principles apply to standard HTML forms as well.

The Problem

By default, HTML forms can be cumbersome to style, especially when trying to align labels and textboxes. The traditional approach involves using tables or floating elements, which can lead to inflexible and brittle layouts. Consider the following registration form coded in Blazor:

<EditForm Model="@userModel" OnValidSubmit="HandleValidSubmit">
    <div class="form-group">
        <label for="ssn">SSN</label>
        <InputText id="ssn" class="form-control" @bind-Value="userModel.SocialSecurityNumber" />
    </div>

    <div class="form-group">
        <label for="name">Name</label>
        <InputText id="name" class="form-control" @bind-Value="userModel.Name"/>
    </div>

    <div class="form-group">
        <label for="email">Email Address</label>
        <InputText id="email" class="form-control" @bind-Value="userModel.EmailAddress"/>
    </div>

    <button type="submit" class="btn btn-primary">Submit</button>
</EditForm>

which, without styling, looks like this:

What we want is to put the labels in one column, and the text boxes in another column, something like this:

The Solution

Flexbox provides a simple and efficient solution to this problem. By applying Flexbox properties to the form groups, we can easily align labels and textboxes. The CSS below will accomplish the job.

.form-group {
    display: flex;
}

.form-group label {
    flex: 1 1 150px; /* Equivalent to:
                        flex-grow: 1;
                        flex-shrink: 1;
                        flex-basis: 150px; */
    text-wrap: nowrap;
}

.form-group input {
    flex: 1 1 0; /* Equivalent to:
                    flex-grow: 1;
                    flex-shrink: 1;
                    flex-basis: 0px; */
}

How it works

  1. In our html form(EditForm above), we wrap each label and input pair in a div with the class form-group.
  2. We set display: flex on the .form-group elements to enable Flexbox layout.
  3. For the labels, we use flex: 1 1 150px, which means:
    • flex-grow: 1: Take up equal space.
    • flex-shrink: 1: Shrink equally if necessary.
    • flex-basis: 150px: Start with a width of 150px, enough for the longest text which is “Email Address
  4. For the inputs, we use flex: 1 1 0, which means:
    • flex-grow: 1: Take up equal space.
    • flex-shrink: 1: Shrink equally if necessary.
    • flex-basis: 0px: Start with no width and expand to fill available space.

Note: flex-grow:0 or flex-shrink:0 means the space will not move no matter how you resize the browser! I use flex-grow:1 and flex-shrink:1 so that when you resize the browser, the space will move as long as it’s within the flex-basis value.

Conclusion

With Flexbox, aligning labels and textboxes in forms becomes a straightforward task. By applying simple CSS rules, you can create responsive, maintainable, and visually appealing forms. This technique can be applied to standard HTML forms as well, making it a valuable tool for any web developer.

    Alejandrio Vasay
    Alejandrio Vasay

    Welcome to Coder Schmoder! I'm a .NET developer with a 15+ years of web and software development experience. I created this blog to impart my knowledge of programming to those who are interested in learning are just beginning in their programming journey.

    I live in DFW, Texas and currently working as a .NET /Web Developer. I earned my Master of Computer Science degree from Texas A&M University, College Station, Texas. I hope, someday, to make enough money to travel to my birth country, the Philippines, and teach software development to people who don't have the means to learn it.

    Articles: 26

    Leave a Reply

    Your email address will not be published. Required fields are marked *