RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 766050
Accepted
humster_spb
humster_spb
Asked:2020-01-03 18:41:10 +0000 UTC2020-01-03 18:41:10 +0000 UTC 2020-01-03 18:41:10 +0000 UTC

jquery:是否可以优化脚本?

  • 772

有一个脚本可以检查是否在间隙中输入了单词:

var check = function(input, word) {
  input.keyup(function(){
    if($(this).val() == word) {
      $(this).css({'color':'green', 'border-bottom-color':'green'});
    }
    else {
      $(this).css({'color':'black', 'border-bottom-color':'gray'});
    }
  });
  input.blur(function(){
    if($(this).val() == word) {
      $(this).css({'color':'green', 'border-bottom-color':'green'});
    }
    else {
      $(this).css({'color':'red', 'border-bottom-color':'red'});
    }
  });
}


check($('#am'), 'am');
check($('#has'), 'has');
check($('#will'), 'will');
input {
  border: none;
  border-bottom: 1px solid gray;
  width: 50px;
  outline: none;
  text-align: center;
}
I <input type="text" id="am" /> a student.<br />
She <input type="text" id="has" /> a dog.<br />
We <input type="text" id="will" /> come home tomorrow.
<script src="https://code.jquery.com/jquery-2.2.0.min.js"></script>

它有两个问题。

第一:有没有可能以某种方式结合keyup和blur?很明显有一个.on('keyup blur', function(){}) 构造,但是else中有不同的颜色。

第二:对于每次检查,您需要使用自己的参数调用检查函数。现在有 3 个,但将有 33 个甚至更多。有没有办法优化这个?

很明显,您可以创建两个数组 - 带有输入和单词 - 并在循环中运行函数调用,在每次迭代时替换数组的相应元素。但我认为这个解决方案并不比目前的解决方案更好。有一些完全不同的选择吗?

javascript
  • 2 2 个回答
  • 10 Views

2 个回答

  • Voted
  1. Best Answer
    Kirill
    2020-01-03T19:44:18Z2020-01-03T19:44:18Z

    var check = function(input, word) {
      input.on('blur keyup', function() { // объединяем ивенты
        if ($(this).val() != word && event.type == 'blur') {
          $(this).css({
            'color': 'red',
            'border-bottom-color': 'red'
          });
        }else if($(this).val() != word && event.type == 'keyup') {
          $(this).css({
            'color': 'black',
            'border-bottom-color': 'black'
          });
        }else {
          $(this).css({
            'color': 'green',
            'border-bottom-color': 'green'
          });
    
        }
      })
    };
    
    $(".chekable").each(function() { // навешиваем функцию на все инпуты в наборе. 
      check($(this), $(this).data('answer'));
    });
    input {
      border: none;
      border-bottom: 1px solid gray;
      width: 50px;
      outline: none;
      text-align: center;
    }
    <script src="https://code.jquery.com/jquery-2.2.0.min.js"></script>
    
    I <input type="text" id="am" class="chekable" data-answer="am" /> a student.<br /> She <input type="text" id="has" class="chekable" data-answer="has" /> a dog.<br /> We <input type="text" id="will" class="chekable" data-answer="will" /> come home tomorrow.

    • 0
  2. Mr.Robot
    2020-01-03T21:22:36Z2020-01-03T21:22:36Z

       function check(i) {
      //проверяем совпадает ли значение с его data-info атрибутом
    
      i.keyup(function(){
           $(this).css(($(this).val() == $(this).attr("data-info")?{'color':'green', 'border-bottom-c olor':'green'}:{'color':'black', 'border-bottom-color':'gray'}));
      });
      i.blur(function(){
          $(this).css(($(this).val() == $(this).attr("data-info")?{'color':'green', 'border-bottom-
          color':'green'}:{'color':'black', 'border-bottom-color':'gray'}));
      });
    }
    
    $(".inp").each(function() { //задаем обработчик событий 
    check($(this));
    });
    input {
      border: none;
      border-bottom: 1px solid gray;
      width: 50px;
      outline: none;
      text-align: center;
    }
    I <input type="text" class="inp" data-info="am"/> a student.<br />
    She <input type="text" class="inp" data-info="has"/> a dog.<br />
    We <input type="text" class="inp" data-info="will"/> come home tomorrow.
    <script src="https://code.jquery.com/jquery-2.2.0.min.js"></script>

    • 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