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/

相关文章:

php - PHP中的JSON数组三个mysql表

python - 字符串中存在特定字符

javascript - 等待 AJAX 调用链完成

javascript - 从 Chrome 下载栏拖放文件上传

javascript - 在 JavaScript 中创建二维数组并推送值

php - 使用以下格式从 PHP 中的 JSON 数组获取值?

VB.NET 获取引号或其他符号之间的文本

c++ - C++设计:基类构造函数和自定义字符串类的is-a或has-a关系

javascript - 使用 Selenium 或 HTMLUNIT 的 HttpClient?

javascript - 从 URL 获取即使在捕获它之后也会在控制台中显示错误?