提交按钮 - 一旦不再禁用,则更改提交按钮的CSS

时间:2017-07-13 14:46:11

标签: html css forms input submit

在我的表单中,在用户输入了所有必填字段(绿色复选标记出现在输入字段中)并且提交按钮不再被禁用后,我希望我的提交按钮具有橙色文本和白色背景,因为它出现在附加图像中,而不是目前看起来像的灰色背景和黑色文本。有谁知道是否有办法改变这个?

Submit Button

JSFiddle



function phoneNumber(phone) {
  var phoneno = /^\d{9}|\d{10}|\d{11}$/;

  console.log("PHONE: " + phoneno.test(phone));
  return phoneno.test(phone);
}

$('input[type="tel"]').on('keyup', function() {
  var $label = $(this).closest('label');
  if ($(this).val().trim() != '') {
    if ($(this).is('#phone')) {
      if (phoneNumber($(this).val())) {
        $label.attr('data-valid', 'valid');
        $(this).next("i").removeClass("fa-times-circle-o").addClass("fa-check-circle");
      } else {
        $label.attr('data-valid', 'error');
        console.log("this works");
        $(this).next("i").removeClass("fa-check-circle").addClass("fa-times-circle-o");
      }
    } else {
      $label.attr('data-valid', 'valid');
      console.log("this works")
    }
  } else {
    $label.removeAttr('data-valid');
    console.log("this works")

  }
});


function validateEmail(email) {
  var re = /^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;

  console.log("email: " + re.test(email));
  return re.test(email);
}

$('input[type="text"]').on('keyup', function() {
  var $label = $(this).closest('label');
  if ($(this).val().trim() != '') {
    if ($(this).is('#email')) {
      if (validateEmail($(this).val())) {
        $label.attr('data-valid', 'valid');
        $(this).next("i").removeClass("fa-times-circle-o").addClass("fa-check-circle");

      } else {
        $label.attr('data-valid', 'error');
        console.log("this works 1")
        $(this).next("i").removeClass("fa-check-circle").addClass("fa-times-circle-o");
      }
    } else {
      $label.attr('data-valid', 'valid');
      console.log("this works 2");
    }
  } else {
    $label.removeAttr('data-valid');
    console.log("this works 3");
  }
});


test = function() {
  if ($("#first_name").val() &&
    $("#last_name").val() &&
    $("#email").val() &&
    $("#phone").val() &&
    $("#city").val() &&
    $("#state").val() &&
    $("#company").val()) {

    $("#sub").removeAttr("disabled");
  }
}
&#13;
body {
  color: #fff;
  background-color: #f78e2a;
  text-align: center;
}

form {
  color: #fff;
  background-color: #f78e2a;
  text-align: center;
  font-family: Lato;
}

* {
  box-sizing: border-box;
}

.form-title {
  font-size: 38px;
  color: #fff;
  font-family: "Lato";
  letter-spacing: 70px;
}

input[type="tel"] {
  width: 100%;
  height: 85%;
  padding: 10px;
  background-color: #f9a558;
  border: 1px solid #fff;
}

input[type="text"] {
  width: 100%;
  padding: 10px;
  background-color: #f9a558;
  border: 1px solid #fff;
}

input[type="text"]:focus {
  background-color: #fff;
}

input[type="text"]:visited {
  background-color: #fff;
}

input[type="tel"]:focus {
  background-color: #fff;
}

input[type="tel"]:visited {
  background-color: #fff;
}

.container {
  display: flex;
  flex-direction: column;
  padding: 5px 0;
  margin-left: 10%;
  margin-right: 10%;
}

textarea {
  width: 100%;
  background-color: #f9a558;
  border: 1px solid #fff;
}

textarea:focus {
  background-color: #fff;
}

#co {
  flex-basis: 100%;
  max-width: 100%;
}

label:nth-last-child(-n+2) {
  flex-basis: 100%;
  max-width: 100%;
}

select,
label {
  height: 50px;
  width: 48%;
  margin: 2% 1%;
  text-align: left;
  font-family: "Lato";
}

#sub {
  border-radius: 6px;
  width: 120px;
  height: 35px;
  text-transform: uppercase;
  display: block;
  margin-top: 10px;
}

button {
  margin-top: 10px;
  background-color: #B9B9B9;
  color: #959595;
  border-radius: 6px;
  width: 120px;
  height: 35px;
  margin-left: 1%;
  display: block;
}

button:focus {
  background-color: #fff;
  color: #f78e2a;
}

@media (max-width: 426px) {
  label {
    width: 98%;
  }
}

@media (min-width: 426px) {
  .container {
    flex-direction: row;
    flex-wrap: wrap;
    align-self: flex-start;
  }
}

label {
  position: relative;
}

.fa {
  position: absolute;
  bottom: 0;
  right: 0;
  transform: translate(-50%, -5%);
  opacity: 0;
  transition: opacity .5s, color .5s;
}

[data-valid] .fa {
  opacity: 1;
  color: green;
}

[data-valid="valid"] .fa {
  color: green;
}

[data-valid="error"] .fa {
  color: red;
}

.error {
  display: none;
  color: red;
  font-size: .7em;
  position: absolute;
  left: 10px;
  top: 0;
  transform: translateY(150%);
}

[data-valid="error"] .error {
  display: block;
}
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<form class="container" action="https://webto.salesforce.com/servlet/servlet.WebToLead?encoding=UTF-8" method="POST">
  <label>First Name
                    <input id="first_name" maxlength="40" name="first_name" size="20" type="text" onkeyup="test()" required><i class="fa fa-check-circle" aria-hidden="true"></i>
                  </label>
  <label>Last Name
                    <input id="last_name" maxlength="80" name="last_name" size="20" type="text" onkeyup="test()"><i class="fa fa-check-circle" aria-hidden="true"></i>
                  </label>
  <label>Email
                    <span class="error">Please enter a valid email address</span>
                    <input id="email" maxlength="80" name="email" size="20" type="text" onkeyup="test()"><i class="fa fa-times-circle-o" aria-hidden="true"></i>
                  </label>
  <label>Phone
                    <span class="error">Please enter a valid phone number</span>              
                    <input id="phone" maxlength="80" name="phone" size="20"    type="tel" onkeyup="test()"><i class="fa fa-times-circle-o" aria-hidden="true"></i>
                  </label>
  <label>City
                    <input id="city" name="city" maxlength="40" size="20" type="text" onkeyup="test()"><i class="fa fa-check-circle" aria-hidden="true"></i>
                  </label>
  <label>State/Province
                    <input id="state" maxlength="20" name="state" size="20" type="text" onkeyup="test()"><i class="fa fa-check-circle" aria-hidden="true"></i>
                  </label>
  <label id="co">Company
                    <input id="company" name="company" type="text" onkeyup="test()"><i class="fa fa-check-circle" aria-hidden="true"></i>
                  </label>
  <label>Comments
                    <textarea id="comments" name="" id="" cols="30" rows="10" onkeyup="test()"></textarea>
                    <input id="sub" type="submit" disabled="disabled" />
                  </label>

  <div>
    <select hidden="true" id="00N6A000008yXMN" name="00N6A000008yXMN" title="Product Interest">
                        <option value="">--None--</option>
                        <option selected="selected" value="Visiant">Visiant</option>
                        <option  value="Tessellate">Tessellate</option>
                    </select><br>

    <select hidden="true" id="lead_source" name="lead_source">
                        <option value="">--None--</option>
                        <option value="Internal">Internal</option>
                    <option value="Trade Show">Trade Show</option>
                    <option selected="selected" value="Website">Website</option>
                    <option value="Direct Marketing">Direct Marketing</option>
                    <option value="Social Media">Social Media</option>
                    <option value="Other">Other</option>
                    </select><br>
  </div>
</form>
&#13;
&#13;
&#13;

2 个答案:

答案 0 :(得分:0)

这只能通过CSS来完成:

根据这两条规则自定义CSS属性。

#sub{  /* enabled */
  background-color:white;
  color:orange;
}
#sub:disabled{  /* disabled */
  background-color:grey;
  color:black;
}

答案 1 :(得分:0)

@Louys在基本级别回答了您的问题,但您可能想检查您的CSS。例如,当您将提交按钮作为元素时,您正在尝试设置元素的样式,因此它不能正确关联这两个元素。除此之外,你的jQuery错误地修改了按钮的状态。

您应该更新CSS以执行以下操作:

#sub {
  border-radius: 6px;
  width: 120px;
  height: 35px;
  text-transform: uppercase;
  display: block;
  margin-top: 10px;
}

#sub:disabled {
  margin-top: 10px;
  background-color: #B9B9B9;
  color: #959595;
  border-radius: 6px;
  width: 120px;
  height: 35px;
  margin-left: 1%;
  display: block;
}

#sub:focus,
#sub:not(:disabled) {
  background-color: #fff;
  color: #f78e2a;
}

请注意我在这里做了什么,以及我如何定位您想要更改的元素。之前,您的目标是一个元素,但您的提交按钮实际上是一个元素。这足以让浏览器循环播放。小心检查你的CSS选择器。此外,我修改你的Javascript更加一点点:

test = function() {
      if
      (
        $("#first_name").parent().attr('data-valid') == 'valid'
        && $("#last_name").parent().attr('data-valid') == 'valid'
        && $("#email").parent().attr('data-valid') == 'valid'
        && $("#phone").parent().attr('data-valid') == 'valid'
    && $("#city").parent().attr('data-valid') == 'valid'
    && $("#state").parent().attr('data-valid') == 'valid'
    && $("#company").parent().attr('data-valid') == 'valid'
  )
  {
    $("#sub").prop("disabled", false);
  }
  else
  {
    $("#sub").prop('disabled', true);
  }
}

查看小提琴我所做的所有更改,以帮助此代码更有效:http://jsfiddle.net/vvffpjxb/11/

请注意,我已经更改了检查值的方式,并且它定位了正确的元素。那就是出了什么问题;你只需要以正确的方式定位正确的元素。此外,如果任何字段无效,我添加了再次禁用按钮的功能。