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

标签 javascript jquery for-loop case-insensitive

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

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>

最佳答案

这里最简单的选择是,不更改其余代码,是等式的大写(或小写)两边,这样您就可以进行比较.

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 的回答,无需在此处重复)- 正则表达式的好处是您无需先转换为上/下。

关于Javascript 在比较单词中的字母时不区分大小写,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52206491/

相关文章:

javascript - 更改 :position event for every cell in the paper using joint. js

javascript - Asp.net MVC 使用 Ajax 从 PartialView 的操作链接加载父 View 不起作用

matlab - 加速用最后一个非 Nan 值替换 NaN

javascript - 如何使用 jquery/Javascript 将段落合并到父链接中?

javascript - jquery替换url图像中的字符串

for-loop - for循环中的Java Card内存泄漏?

windows - 批处理文件 FOR/f 标记

javascript - 多页面应用 React Router v4

javascript - 在 JavaScript 中设置/获取样式高度

Javascript使一个词不可编辑到文本区域