Forms are the primary means for users to interact with web applications. In Laravel, a PHP framework known for its elegance and efficiency, handling forms and validating user input is a breeze. Let's explore advanced Laravel form handling and validation using HTML tags to illustrate the key concepts.


HTML Forms


First, let's create a simple HTML form:


        
<form action="/submit" method="POST">
@csrf
<label for="name">Name:</label>
<input type="text" name="name" id="name">
<br>
<label for="email">Email:</label>
<input type="email" name="email" id="email">
<br>
<input type="submit" value="Submit">
</form>

This HTML form collects user information, including their name and email.


Laravel Form Handling


In your Laravel controller, you can access the form data using the `request()` function:


        
public function submitForm(Request $request) {
$name = $request->input('name');
$email = $request->input('email');
// Process and store the data
}

Laravel Validation


Now, let's validate the user input. Laravel provides an elegant way to define validation rules:


        
public function submitForm(Request $request) {
$validatedData = $request->validate([
'name' => 'required|string|max:255',
'email' => 'required|email|max:255',
]); // The data is validated, you can now safely use it
}

If the input doesn't meet the specified criteria (e.g., if `name` is empty or `email` is not a valid email address), Laravel will return appropriate error messages to the view.


Displaying Validation Errors


To display validation errors in your view, you can use the `@error` directive:


        
@if ($errors->any())
<div class="alert alert-danger">
<ul>
@foreach ($errors->all() as $error)
<li>{{ $error }}</li>
@endforeach
</ul>
</div>
@endif

This code will display a list of validation errors, if any, in your view.


Advanced Laravel form handling and validation simplify the process of collecting and ensuring the accuracy of user input, making your web applications more robust and user-friendly.