首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Jquery -如何在不使用长度的情况下编写代码?

Jquery -如何在不使用长度的情况下编写代码?
EN

Stack Overflow用户
提问于 2018-08-03 04:49:28
回答 3查看 56关注 0票数 0

我有下面的jQuery代码,我正在使用它进行表单验证,它可以工作,但Typescript不喜欢它,我是Javascript的菜鸟(typescript远远超过noob)。

有没有其他方法可以在不使用长度的情况下成功地编写下面的代码?

代码语言:javascript
复制
 $('input[required], select[required], textarea[required]').on('change, input', function(e) {
    var rc = 0;
    $('[required]').each(function() {
      if($(this).val().length === 0) {
        rc++;
      }
    });
    if(rc === 0) {
      $('button').prop("disabled", false);
    } else {
      $('button').prop("disabled", true);
    }
});
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2018-08-03 05:00:40

如果你坚持不检查长度,可以试试if(!$(this).val()),而不是if($(this).val().length === 0)。这是检查字符串是否为空的另一种方法,因为在JavaScript中,空字符串是一个“False值”。

票数 0
EN

Stack Overflow用户

发布于 2018-08-03 05:01:22

您可以只检查空字符串,因为这无论如何都会计算为false。if(!$(this).val())或仅使用!!$(this).val()返回布尔值

所以你的代码可能是这样的

代码语言:javascript
复制
$('input[required], select[required], textarea[required]').on('change, input', function(e) {
    $('[required]').each(function() {
      var disabled = !!$(this).val();
      if(disabled) return false;
    });
    $('button').prop("disabled", disabled);
});
票数 0
EN

Stack Overflow用户

发布于 2018-08-03 09:45:11

您应该首先对值执行trim操作(删除所有尾随空格),以确保它不仅仅是空格。

代码语言:javascript
复制
if(!$(this).val().trim()){
  //String is null, empty, or only spaces
}

演示:

代码语言:javascript
复制
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<input type="text" id="inputToCheck"><button onClick="check()">Check</button>
<p/>
<span id="result"></span>
<script>
var inputToCheck = $('#inputToCheck');
var result = $('#result');
function check(){
  if(!inputToCheck.val().trim()){
   alert("Invalid input!");
   result.html("<b style='color: red;'>Input is not valid (empty or only whitespace).</b>");
  } else {
    result.text("Input is not null, empty, or only white space.");
  }
}
</script>

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51661952

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档