使用Javsacript从输入中删除:valid伪类

时间:2019-04-03 10:36:35

标签: javascript validation bootstrap-4

我有一个包含多个部分的表格。每个部分均使用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>

1 个答案:

答案 0 :(得分:1)

据我所知,您根本无法摆脱public function getSpecificProductAttribute() { return $this->products() ->where('column','value')->first(); } 伪类。

但是,这里的问题不是那些伪类。将:valid类添加到表单中时,只要您在适当的地方手动添加was-validated类,Bootstrap 4就会按照问题的要求进行操作。

按照Bootstrap 4 documentation

  

作为后备,可以使用.is-invalid和.is-valid类代替用于服务器端验证的伪类。 它们不需要.was验证的父类。

(强调我的。)

您看到is-invalid:valid伪类样式化的原因是由于父类上的:invalid类:

  

Bootstrap将:invalid和:valid样式的作用域限定为父.was-validated类,通常应用于

。否则,任何没有值的必填字段在页面加载时都将显示为无效。这样,您可以选择何时激活它们(通常在尝试提交表单之后)。