Components

Select

{note} You're browsing the documentation for an old version of laravel-form-components. Consider upgrading your project to v8. Check your version with the following command:

composer show rawilk/laravel-form-components

The select component offers an easy way to provide select menus in your forms. By simply setting the name attribute it also automatically defines your id and makes sure old values are respected.

The most basic usage of the component involves setting a name attribute:

<x-select name="state" />

This will output:

<div class="form-text-container">
    <select name="state"
            id="state"
            class="form-select"
    >
    </select>
</div>

Of course, the id attribute can easily be overridden:

<x-select name="state" id="state_id" />

This will output:

<div class="form-text-container">
    <select name="state"
            id="state_id"
            class="form-select"
    >
    </select>
</div>

There are multiple ways to provide options to the component. The primary way is to provide an array of options as key/value pairs. This will allow the select component to automatically determine which option should be selected (as long as you're not using wire:model) for you.

<x-select name="state" :options="['al' => 'Alabama', 'wi' => 'Wisconsin']" />

This will output:

<div class="form-text-container">
    <select name="state"
            id="state"
            class="form-select"
    >
        <option value="al">Alabama</option>
        <option value="wi">Wisconsin</option>
    </select>
</div>

Another way is to use the default slot on the component:

<x-select name="state">
    <option value="al">Alabama</option>
    <option value="wi">Wisconsin</option>
</x-select>

This will output:

<div class="form-text-container">
    <select name="state"
            id="state"
            class="form-select"
    >
        <option value="al">Alabama</option>
        <option value="wi">Wisconsin</option>
    </select>
</div>

You can also use the append slot if you are passing in options via the options attribute, and it will add your slotted options after the passed in options:

<x-select name="state" :options="['ny' => 'New York']">
    <x-slot name="append">
        <option value="al">Alabama</option>
        <option value="wi">Wisconsin</option>
    </x-slot>
</x-select>

This will output:

<div class="form-text-container">
    <select name="state"
            id="state"
            class="form-select"
    >
        <option value="ny">New York</option>
        <option value="al">Alabama</option>
        <option value="wi">Wisconsin</option>
    </select>
</div>

You can also pass in options using multiple methods. For example, if you pass options in using the options attribute, and also via the default slot, your slotted options will be rendered before the passed in options:

<x-select name="state" :options="['ny' => 'New York']">
    <option value="al">Alabama</option>
    <option value="wi">Wisconsin</option>
</x-select>

This will output:

<div class="form-text-container">
    <select name="state"
            id="state"
            class="form-select"
    >
        <option value="al">Alabama</option>
        <option value="wi">Wisconsin</option>
        <option value="ny">New York</option>
    </select>
</div>

You can easily create a multiple select by setting multiple to true:

<x-select name="state" :options="['al' => 'Alabama', 'wi' => 'Wisconsin']" multiple />

This will output:

<div class="form-text-container">
    <select name="state"
            id="state"
            class="form-select"
            multiple
    >
        <option value="al">Alabama</option>
        <option value="wi">Wisconsin</option>
    </select>
</div>

Since the select component extends the input component, you are able to do a lot of the same things you can with the input element, such as error handling and addons.

Previous
Textarea
Caught a mistake? Suggest an edit on GitHub