我有一个包含多个部分的表格。每个部分均使用Bootstrap 4验证手动验证(无需提交真实表单)。可以在下面的代码中正常工作;
let eventCreationForm = $(".event-creation-form");
if (!eventCreationForm[0].checkValidity()) {
eventCreationForm.find(":submit").click();
}
但是,我只想突出显示无效的输入。也就是说,请勿以绿色突出显示有效输入。我认为,我不会覆盖引导程序样式,而是尝试从有效输入中删除:valid
伪类。但是,我找不到任何这样做的例子。我一直在研究的问题只是通过CSS更改了样式。
我认为类似的事情可能会起作用,
eventCreationForm.find(":valid").removeClass(":valid");
,但我想不是,因为它不是真正的课程。
下面的示例有一个调用堆栈错误,但这仅是该示例。
$(document).ready(function(){
var forms = document.getElementsByClassName('needs-validation');
var validation = Array.prototype.filter.call(forms, function(form) {
form.addEventListener('submit', function(event) {
if (form.checkValidity() === false) {
event.preventDefault();
event.stopPropagation();
}
form.classList.add('was-validated');
}, false);
});
$(".manual-submit").click(function(){
let eventCreationForm = $(".event-creation-form");
if (!eventCreationForm[0].checkValidity()) {
eventCreationForm.find(":submit").click();
}
})
})
<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js" integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz0W1" crossorigin="anonymous"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js" integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM" crossorigin="anonymous"></script>
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous">
<form class="needs-validation event-creation-form" novalidate>
<div class="form-row">
<div class="col-md-4 mb-3">
<label for="validationCustom01">First name</label>
<input type="text" class="form-control" id="validationCustom01" placeholder="First name" value="Mark" required>
<div class="valid-feedback">
Looks good!
</div>
</div>
<div class="col-md-4 mb-3">
<label for="validationCustomUsername">Username</label>
<div class="input-group">
<div class="input-group-prepend">
<span class="input-group-text" id="inputGroupPrepend">@</span>
</div>
<input type="text" class="form-control" id="validationCustomUsername" placeholder="Username" aria-describedby="inputGroupPrepend" required>
<div class="invalid-feedback">
Please choose a username.
</div>
</div>
</div>
</div>
<button class="btn btn-primary manual-submit">Submit form</button>
</form>
答案 0 :(得分:1)
据我所知,您根本无法摆脱public function getSpecificProductAttribute()
{
return $this->products()
->where('column','value')->first();
}
伪类。
但是,这里的问题不是那些伪类。将:valid
类添加到表单中时,只要您在适当的地方手动添加was-validated
类,Bootstrap 4就会按照问题的要求进行操作。
作为后备,可以使用.is-invalid和.is-valid类代替用于服务器端验证的伪类。 它们不需要.was验证的父类。
(强调我的。)
您看到is-invalid
和:valid
伪类样式化的原因是由于父类上的:invalid
类:
Bootstrap将:invalid和:valid样式的作用域限定为父.was-validated类,通常应用于