Другое событие NullPointerException
возникает, когда объявляется массив объектов, а затем сразу же пытается разыменовать его внутри.
String[] phrases = new String[10];
String keyPhrase = "Bird";
for(String phrase : phrases) {
System.out.println(phrase.equals(keyPhrase));
}
Этот конкретный NPE можно избежать, если порядок сравнения отменяется ; а именно, использовать .equals
для гарантированного непустого объекта.
Все элементы внутри массива инициализируются их общим начальным значением ; для любого типа массива объектов, это означает, что все элементы null
.
Вы должны инициализировать элементы в массиве перед доступом или разыменованием их.
String[] phrases = new String[] {"The bird", "A bird", "My bird", "Bird"};
String keyPhrase = "Bird";
for(String phrase : phrases) {
System.out.println(phrase.equals(keyPhrase));
}
Необходимо будет препятствовать тому, чтобы форма была отправлена, пока reCAPTCHA маркер не вставляется в форму. Можно достигнуть этого при помощи глобальной переменной, которая установлена после загрузки reCAPTCHA и проверена прежде, чем отправить форму:
<script src='https://www.google.com/recaptcha/api.js?render={{config("recaptcha.key")}}'></script>
<script>
// Whether the reCAPTCHA token is loaded into the form
var recaptchaLoaded = false;
// Whether the user already attempted submitting the form
var attemptedSubmit = false;
grecaptcha.ready(function () {
grecaptcha.execute('{{config("recaptcha.key")}}', {action: '{{$action}}'}).then(function (token) {
$('<input />').attr('type', 'hidden')
.attr('name', 'recaptcha')
.attr('value', token)
.appendTo('form');
window.recaptchaLoaded = true;
if(window.attemptedSubmit) {
// As the user already attempted a submit,
// trigger the "submit" mechanism
// Note that this doesn't trigger the JS "submit" event
$("#form").submit();
}
});
});
// Add an event listener for "submit"
$("#form").submit(function(event) {
window.attemptedSubmit = true;
if(!window.recaptchaLoaded) {
// The reCAPTCHA token has not been inserted
// Prevent submission of the form
event.preventDefault();
// Your button animation logic here...
}
});
</script>