My project is based on laravel 8 & php 7.4.
I've a signup form based on Ajax. I' m asking the user to enter the password and then confirm password. I'm handling the validation in json response. My all fields are validated properly and working but I don't know how should I validate the confirm password field to match the password.
Blade
<form id="register_forms">
<div>
<label for="register_password"></label>
<input placeholder="password" id="register_password" type="password" class="input form-control @error('register_password') is-invalid @enderror" name="register_password" required autocomplete="register_password">
<span class="message" id="register_password" style="color: #ff0000; display:none;" role="alert"><strong>{{ __('The password field is required.')}}</strong></span>
</div>
<div>
<label for="register_password_confirmation"></label>
<input placeholder="confirm Password" type="password" class="input form-control" name="register_password_confirmation" required autocomplete="new-password">
</div>
<input id="my-register" type="submit" value="Continue">
</form>
JavaScript
<script>
$("#my-register").click(function(e){
e.preventDefault();
var _token = $('input[name="_token"]').val();
var data = $('#register_forms').serialize()
$.ajaxSetup({
headers: {
'X-CSRF-TOKEN': $('meta[name="_token"]').attr('content')
}
});
$.ajax({
type: "post",
beforeSend: function(){
$('.ajax-loader').css("visibility", "visible");
},
url: "{{ route('register') }}",
data: $('#register_forms').serialize(),
//data : $('#register_forms').serialize() + "&_token=" + _token,
dataType: 'json',
success: function(data) {
window.location = "https://carchainclassics.com/login";
},
complete: function(){
$('.ajax-loader').css("visibility", "hidden");
},
error: function (err) {
$('.message').hide();
if (err.status == 422) {
$('#success_message').fadeIn().html(err.responseJSON.message);
// display errors on each form field
$.each(err.responseJSON.errors, function (i, error) {
grecaptcha.reset();
var el = $(document).find('span[id="'+i+'"]');
el.show();
});
}
}
});
/**Ajax code ends**/
});
</script>
Controller
protected function validator(array $data)
{
'register_password' => ['required','string', 'min:8','confirmed'],
]);
$validator->setAttributeNames([
'register_password' => 'password',
]);
return $validator;
}