比较单词中的字母时,Javascript不区分大小写

问题描述 投票:1回答:4

我有这个练习,用户输入一个单词,然后输入一个字母,看看该单词出现多少次。这部分项目运作得很好。但是,我想让它不区分大小写,因为现在它不是。我想创建一个大写变量和一个小写变量,然后将这些变量与i或字母变量进行比较。但是,它使计数器的数量增加了一倍。有人能帮我吗?这是我的代码:

function checkWordAndLetter() {
  var userWord = $("#word").val();
  console.log(userWord);
  var userLetter = $("#letter").val();
  console.log(userLetter);
  var letterUpperCase = userLetter.toUpperCase();
  var letterLowerCase = userLetter.toLowerCase();
  var tally = 0;
  for (i = 0; i < userWord.length; i++) {
    if (userLetter == userWord[i] && i == letterUpperCase ||
      letterLowerCase) {
      tally++;
    }
  }
  console.log(tally);
  $("#letterResults").html(" There are " + tally + " " + userLetter + "'s  in the word " + userWord);
  console.log("apple");
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div id="mainPage">
  <h2>Find the Letter in the Word</h2>
  <h4>Enter a word and select a letter to see how many times that letter appears in the word</h2>
    <p>Enter below:</p>
    <br/> Word:
    <input id="word" type="text" name="word"><br/><br/> Letter: <input id="letter" type="text" name="letter"><br/><br/>
    <br/>
    <br/>
    <button id="submit" type="button" name="submit" onclick="checkWordAndLetter()">submit</button>
    <p id="letterResults"></p>
</div>
javascript jquery for-loop case-insensitive
4个回答
2
投票

这里最简单的选择,不改变你的代码的其余部分,是在等式两边的上(或下)情况,所以你比较喜欢。

function checkWordAndLetter() {
  var userWord = $("#word").val();
  var userLetter = $("#letter").val();
  var userWordUpper = userWord.toUpperCase();
  var userLetterUpper = userLetter.toUpperCase();
  var tally = 0;
  for (var i = 0; i < userWord.length; i++) {
    if (userLetterUpper == userWordUpper[i]) {
      tally++;
    }
  }
  $("#letterResults").html(" There are " + tally + " " + userLetter + "'s in the word " + userWord);
}
$("#word,#letter").change(checkWordAndLetter)

checkWordAndLetter();
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<input type='text' id='word' value='hello'/>
<input type='text' id='letter' value='l' />
<div id='letterResults'></div>

在您的原始代码中,此行:

if (userLetter == userWord[i] && i == letterUpperCase || letterLowerCase) {

可能是:

if (letterUpperCase == userWord[i] || letterLowerCase == userWord[i]) {

另一种选择可能是使用.split(),它通过打破指定的字符将字符串分隔成一个数组。通常这将是,,但你可以使用任何字母:

var tally = userWordUpper.split(userLetterUpper).length - 1;

function checkWordAndLetter() {
  var userWord = $("#word").val();
  var userLetter = $("#letter").val();

  var userWordUpper = userWord.toUpperCase();
  var userLetterUpper = userLetter.toUpperCase();

  var tally = userWordUpper.split(userLetterUpper).length - 1;

  $("#letterResults").html(" There are " + tally + " " + userLetter + "'s in the word " + userWord);
}
$("#word,#letter").change(checkWordAndLetter)

checkWordAndLetter();
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<input type='text' id='word' value='hello' />
<input type='text' id='letter' value='l' />
<div id='letterResults'></div>

另一种选择是用于正则表达式(编辑:请参阅Rory的答案,不需要在此重复) - 正则表达式的好处是您不需要先转换为上/下。


1
投票

如果你想计算一个字母在一个单词不区分大小写中出现多少,那么在迭代单词之前将单词和字母放在一边。通过这种方式,您将比较相同的字母。例:

let tally = 0;
let letter = "a";
let word = "cAaatttt";
word = word.toLowerCase();
letter = letter.toLowerCase();
for (let i = 0; i < word.length; i++) {
    if (word[i] === letter) tally++;
}

0
投票

要使用当前代码执行所需操作,请将单词和字母字符串转换为匹配大小写,然后进行比较。您可以使用toLowerCase()toUpperCase()来做到这一点。

但是,您可以通过创建正则表达式并使用大小写不敏感标记(i)和match()来进一步简化代码,如下所示:

$('#submit').click(function() {
  var userWord = $("#word").val();
  var userLetter = $("#letter").val();
  
  var re = new RegExp(userLetter, 'gi');
  var tally = userWord.match(re).length;
  
  $("#letterResults").html(`There are ${tally} ${userLetter}'s  in the word ${userWord}`);
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div id="mainPage">
  Word: <input id="word" type="text" name="word"><br/><br/> 
  Letter: <input id="letter" type="text" name="letter"><br/><br/>
  <button id="submit" type="button" name="submit">submit</button>
  <p id="letterResults"></p>
</div>

还要注意在这里使用不显眼的事件处理程序而不是过时的on*事件属性,您应该避免使用它。


0
投票

将单词转换为小写并使用小写字母进行检查。你不需要做uppercase === letter || lowercase === letter。另一个问题是你的if语句,正如其他人已经指出的那样。

您也可以在一行中使用RegExp:

const letter = 'a'
const word = 'pizza potatoes and hamburgers'
const reg = new RegExp(letter, 'gi')
const count = (word.match(reg) || []).length // 4, 0 if no letters found
© www.soinside.com 2019 - 2024. All rights reserved.