JavaScript 字符串数组不进行比较

标签 javascript arrays string compare equality

该程序应该从 2 个文本文件中获取输入。第一个保存数据对,每对都位于自己的文本行上。第一部分是一个单词,第二部分是代表重量的数字。第二个文件是单词列表,每个单词独占一行。我已经测试了输入流,我知道文件正在输入到每个数组中。当我去比较字符串的组合时,单词不会被认为是相等的。我已检查以确保它们是基本字符串而不是对象。我尝试过 ==、=== 和 localeCompare() 但没有成功。我已经 trim 了字符串,使用 valueOf() 和 toString() 也不起作用。任何帮助将不胜感激。

<!-- File:  Enter filename -->
<!DOCTYPE html>

<html>

<head>
  <meta charset="utf-8">
  <title>Mod D 3: Revenge of the JS</title>
</head>

<body>
  <input onchange="loadFile(id)" type="file" name="fileName" id="firstFile" accept=".txt">
  <br>
  <input onchange="loadFile(id)" type="file" name="fileName2" id="secondFile" accept=".txt">
  <br>
  <br>
  <button onclick="compareFiles()">compare files</button>
  <br>
  <br>

  <textarea readonly name="textStuff" id="textStuff" cols="30" rows="15" style="resize none;" data-role="none"></textarea>
  <script>
    var display = document.getElementById("textStuff");
    var file1Words = [];
    var file1Weight = [];
    var file2Words = [];
    var words = [];
    var testingFiles = false;

    function loadFile(idname) {
      console.log("arrived at load function");
      var file = document.getElementById(idname).files[0];
      var reader = new FileReader();
      reader.onload = function(progressEvent) {
        var lineNum = this.result.split('\n');
        if (idname == 'firstFile') {
          console.log("found the first file");
          for (var i = 0; i < lineNum.length; i++) {
            var holder = lineNum[i].split(" ");
            console.log("loading...");
            file1Words.push(holder[0]);
            file1Weight.push(Number(holder[1]));
          }
        } else if (idname == 'secondFile') {
          console.log("found second file");
          for (var i = 0; i < lineNum.length; i++) {
            console.log("loading...");
            file2Words.push(lineNum[i]);
          }
        }
      };
      reader.readAsText(file);
    };

    function compareFiles() {
      console.log("in the compare function");
      if (file1Words.length == 0 || file2Words.length == 0) {
        console.log("why no stuff");
        alert("You must input both files");
        return;
      }
      if (testingFiles) {
        console.log("testing the files");
        display.value = "";
        for (var i = 0; i < file1Words.length; i++) {
          display.value += file1Words[i] + " " + file1Weight[i] + '\n';
        }
        for (var i = 0; i < file2Words.length; i++) {
          display.value += file2Words[i];
        }
      }

      // loop through the arrays
      for (var i = 0; i < file1Words.length; i++) {
        var s1 = file1Words[i];
        for (var j = 0; j < file2Words.length; j++) {
          //console.log(file1Words[i] + " " + file2Words[j]);
          var s2 = file2Words[j];
          console.log(s1 + " " + s2);
          console.log(s1.localeCompare(s2));
          if (s1.localeCompare(s2) == 0) {
            console.log("found something. sending to next func");
          }
        }
      }

    };

    function compareToSaved() {
      console.log("found a match. comparing to see if top 15");
    };
  </script>

</body>

</html>

最佳答案

在第二个单词列表 - file2Words 中, 最后还添加了一个回车符。

因此第二个 file2Words 总是比 file1Words 多一个字符。

您可以通过打印两个数组中字符串的长度来检查这一点。 如下图。

这还将 file2Words 的最后一个字符的 ascii 代码打印为 13(回车)

for (var i = 0; i < file1Words.length; i++) {
        var s1 = file1Words[i];
        for (var j = 0; j < file2Words.length; j++) {
          //console.log(file1Words[i] + " " + file2Words[j]);
          var s2 = file2Words[j];

          console.log(","+s1 + "," + s2 + ",");
          console.log(s1.length)
          console.log(s2.length)
        console.log(s2.charCodeAt(s2.length-1))

          console.log(s1.localeCompare(s2));
          if (s1.localeCompare(s2) == 0) {
            console.log("found something. sending to next func");
          }
        }
      }

    };

要解决此问题,请在将单词添加到其他答案中提到的列表之前使用trim()。

关于JavaScript 字符串数组不进行比较,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41950322/

相关文章:

javascript - 需要检测 Javascript : function calls/args - ANTLR?

javascript - JSFiddle 示例 - React,无法更新渲染

javascript - 在php中的一些记录后显示更多显示

c# - 将整个对象数组转换为字符串

python - 将此字符串格式化为列表的最简单但不是最快的方法是什么? Python

javascript - Laravel 中的 SweetAlert 实现

C 数组索引和访问越界

.net - 将通用列表与数组进行比较

javascript - 数组元素上的 Substr(如果不为空)

python - 正则表达式 : replace comma in string, Python