RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 849570
Accepted
Nice
Nice
Asked:2020-07-03 17:18:22 +0000 UTC2020-07-03 17:18:22 +0000 UTC 2020-07-03 17:18:22 +0000 UTC

使用 jQuery 设置字段样式

  • 772

如何确保当我单击“计算”按钮时,如果某些选择值为 0,它们会以红色边框突出显示,现在它们都被突出显示,无论它们的值是否为 0。即使是选定的也以红色突出显示:

var selectLength = $("#length");
var selectStudents = $("#students");
var selectDuration = $("#duration");
var selectValidity = $("#validity");
var selectQuantity = $("#quantity");
var selectIntro = $("#intro-class");

$("#button-result").on("click", function() {
  if (!!!selectLength.val() || !!!selectStudents.val() || !!!selectDuration.val() || !!!selectValidity.val() || !!!selectQuantity.val()) {
    $("select:not(#intro-class)").addClass("sel-color");
  } else {
    $("select:not(#intro-class)").removeClass("sel-color");
  }
});

$("#length, #duration, #quantity, #validity, #students").change(function() {
      if ($("select").val() != 0) {
        $(this).addClass('sel-color');
      } else {
        $(this).removeClass('sel-color');
      }

      $("#button-clear").click(function() {
        $("select").val('0');
        $('select').attr('disabled', false);
        $("#result-culc").html('');
      });

    }
  select {
    border: 3px solid #4A6695;
  }
  .sel-color {
    border: 3px solid #B80001;
  }
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="wrap-calc">
  <label for="length">French course</label>
  <select id="length" name="length">
    <option value="0">Choose</option>
    <option value="General">General Course</option>
    <option value="Exams">Exams Preparation</option>
    <option value="General">Conversational French</option>
    <option value="Exams">Business French</option>
    <option value="Exams">Civilisation française</option>
  </select>
</div>
<div class="wrap-calc">
  <label for="students">For how many students?</label>
  <select id="students" name="students">
    <option value="0">Choose</option>
    <option value="indiv">Individual</option>
    <option value="group">2-3 people</option>
  </select>
</div>
<div class="wrap-calc">
  <label for="duration">Lesson duration</label>
  <select id="duration" name="duration">
    <option value="0">Choose</option>
    <option value="lesDur-30">30 minutes</option>
    <option value="lesDur-60">60 minutes</option>
  </select>
</div>
<div class="wrap-calc">
  <label for="validity">Plan validity</label>
  <select id="validity" name="validity">
    <option value="0" selected="" disabled="">Choose</option>
    <option id="1mon" value="1month">One month</option>
    <option id="3mon" value="3months">Three months</option>
  </select>
</div>
<div class="wrap-calc">
  <label for="quantity">Quantity of lessons</label>
  <select id="quantity" name="quantity">
    <option value="0" selected="" disabled="">Choose</option>
    <option id="q4" value="Quantity-4">4 lessons</option>
    <option id="q8" value="Quantity-8">8 lessons</option>
    <option id="q12" value="Quantity-12">12 lessons</option>
    <option id="q36" value="Quantity-36">36 lessons</option>
  </select>
</div>
<p id="warn">Please, fill in all the fields</p>

<div class="wrap-calc d-flex justify-content-between">
  <div id="button-clear" class="submit-block submit-block__culc">
    <p>Clear</p>
  </div>
  <div id="button-result" class="submit-block submit-block__culc">
    <p>Calculate</p>
  </div>
</div>
<div class="wrap-calc">
  <div class="submit-block">
    <p>This French course costs : <span value="0" id="result-culc"></span> euros</p>
  </div>
</div>

html
  • 2 2 个回答
  • 10 Views

2 个回答

  • Voted
  1. Best Answer
    Kosta B.
    2020-07-03T18:05:03Z2020-07-03T18:05:03Z

    如何确保当我单击“计算”按钮时,如果某些选择值为 0,它们会以红色边框突出显示,现在它们都被突出显示,无论它们的值是否为 0。

    这是一个选项

    var selectLength = $("#length");
    var selectStudents = $("#students");
    var selectDuration = $("#duration");
    var selectValidity = $("#validity");
    var selectQuantity = $("#quantity");
    var selectIntro = $("#intro-class");
    
    $("#button-result").on("click", function() {
    
      $('select').each(function(i) { // Проходит по всем селектам
        if ($(this).val() === '0') // Сравненте по "0"
          $(this).addClass('sel-color');
        else
          $(this).addClass('sel-color-success'); // Если все првально
      });
    });
    
    $("#length, #duration, #quantity, #validity, #students").change(function() {
      if (+$("select").val() !== 0) { // + переводит в цифры "0"
        $(this).addClass('sel-color');
      } else {
        $(this).removeClass('sel-color');
      }
    
    })
    
    $("#button-clear").on('click', function() {
      $('select').each(function(i) { // Проходит по всем селектам
        $(this).removeClass('sel-color sel-color-success').removeAttr('disabled').val('0');;
      });
      $("#result-culc").html('');
    });
    select {
      border: 3px solid #4A6695;
    }
    
    .sel-color {
      border: 3px solid #B80001;
    }
    
    .sel-color-success {
      border: 3px solid green;
    }
    
    #button-clear:hover,
    #button-result:hover {
      cursor: pointer;
    }
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
    <div class="wrap-calc">
      <label for="length">French course</label>
      <select id="length" name="length">
        <option value="0">Choose</option>
        <option value="General">General Course</option>
        <option value="Exams">Exams Preparation</option>
        <option value="General">Conversational French</option>
        <option value="Exams">Business French</option>
        <option value="Exams">Civilisation française</option>
      </select>
    </div>
    <div class="wrap-calc">
      <label for="students">For how many students?</label>
      <select id="students" name="students">
        <option value="0">Choose</option>
        <option value="indiv">Individual</option>
        <option value="group">2-3 people</option>
      </select>
    </div>
    <div class="wrap-calc">
      <label for="duration">Lesson duration</label>
      <select id="duration" name="duration">
        <option value="0">Choose</option>
        <option value="lesDur-30">30 minutes</option>
        <option value="lesDur-60">60 minutes</option>
      </select>
    </div>
    <div class="wrap-calc">
      <label for="validity">Plan validity</label>
      <!-------- Disable on select not on option -------->
      <select id="validity" name="validity" selected="" disabled="">
        <option value="0">Choose</option>
        <option id="1mon" value="1month">One month</option>
        <option id="3mon" value="3months">Three months</option>
      </select>
    </div>
    <div class="wrap-calc">
      <label for="quantity">Quantity of lessons</label>
      <!-------- Disable on select not on option -------->
      <select id="quantity" name="quantity" selected="" disabled="">
        <option value="0">Choose</option>
        <option id="q4" value="Quantity-4">4 lessons</option>
        <option id="q8" value="Quantity-8">8 lessons</option>
        <option id="q12" value="Quantity-12">12 lessons</option>
        <option id="q36" value="Quantity-36">36 lessons</option>
      </select>
    </div>
    <p id="warn">Please, fill in all the fields</p>
    
    <div class="wrap-calc d-flex justify-content-between">
      <div id="button-clear" class="submit-block submit-block__culc">
        <p>Clear</p>
      </div>
      <div id="button-result" class="submit-block submit-block__culc">
        <p>Calculate</p>
      </div>
    </div>
    <div class="wrap-calc">
      <div class="submit-block">
        <p>This French course costs : <span value="0" id="result-culc"></span> euros</p>
      </div>
    </div>

    • 1
  2. Hikikomori
    2020-07-03T17:31:48Z2020-07-03T17:31:48Z

    $("select") 选择所有选择。如果你想单独浏览每一个,你需要使用 .each。

    或多或少像这样

    $("#length, #duration, #quantity, #validity, #students").change(function(){
      $("select").removeClass('sel-color');
      $("select").each(function(){
        if($(this).val() != 0){
          $(this).addClass('sel-color');
        }
      });
    }):

    • 0

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    是否可以在 C++ 中继承类 <---> 结构?

    • 2 个回答
  • Marko Smith

    这种神经网络架构适合文本分类吗?

    • 1 个回答
  • Marko Smith

    为什么分配的工作方式不同?

    • 3 个回答
  • Marko Smith

    控制台中的光标坐标

    • 1 个回答
  • Marko Smith

    如何在 C++ 中删除类的实例?

    • 4 个回答
  • Marko Smith

    点是否属于线段的问题

    • 2 个回答
  • Marko Smith

    json结构错误

    • 1 个回答
  • Marko Smith

    ServiceWorker 中的“获取”事件

    • 1 个回答
  • Marko Smith

    c ++控制台应用程序exe文件[重复]

    • 1 个回答
  • Marko Smith

    按多列从sql表中选择

    • 1 个回答
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Suvitruf - Andrei Apanasik 什么是空? 2020-08-21 01:48:09 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5