RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1077593
Accepted
Мирас Текесбаев
Мирас Текесбаев
Asked:2020-02-03 14:06:22 +0000 UTC2020-02-03 14:06:22 +0000 UTC 2020-02-03 14:06:22 +0000 UTC

changeFirstSymbol 函数不起作用。帮助伙计们

  • 772

大家好!有一个问题:给定一个字符串。将此行中每个单词的第一个字符大写。为此,请创建一个 ucfirst 辅助函数,该函数将接受一个字符串,将该字符串的第一个字符大写,然后返回首字母大写的字符串。

必须通过单独分离每个函数并将它们声明在一个主函数中来解决该任务。我的实现是这样的:

    <input type="text" class="input">


    let input = document.querySelector('.input');
    input.addEventListener('blur', changeFirstSymbol);

    changeFirstSymbol(input.value);

    function changeFirstSymbol(str) {
        getString(ucFirst(getArrayFromString(str)));
    }

    function getArrayFromString(str) {
        arr = str.split(' ');
        return arr;
    }

    function ucFirst(arr) {
        let newArr = [];
        for (let i = 0; i < arr.length; i++) {
            newArr[i] = arr[i].substr(0, 1).toUpperCase() + arr[i].substr(1);
        }
        return newArr;
    }

    function getString(arr) {
        str = arr.join(' ');
        return str;
    } 

控制台抛出以下错误:

    Uncaught TypeError: str.split is not a function (main.js:12)
    at getArrayFromString (main.js:12)
    at HTMLInputElement.changeFirstSymbol (main.js:8)

让我知道您是否有任何想法?

javascript
  • 2 2 个回答
  • 10 Views

2 个回答

  • Voted
  1. Denis640Kb
    2020-02-03T14:44:59Z2020-02-03T14:44:59Z

    一般来说,几乎所有内容都是正确的,只有少量编辑。

    let input = document.querySelector('.input');
    input.addEventListener('blur', changeFirstSymbol);
    
    changeFirstSymbol(); // Тут не надо задавать параметр.
    
    function changeFirstSymbol() {
        let v = input.value; //Параметр получаем в этой функции 
        let z = getString(ucFirst(getArrayFromString(v))); // получаем значения выполненных операций
        console.log(z); // выводим значение (Для демонстрации) А так можно записать и в input обратно и так далее
        return z;
    }
    
    function getArrayFromString(str) {
        let arr = str.split(' '); // не забываем let, так как в данной функции arr не была ещё объявлена, а через параметры она не передаётся
        return arr;
    }
    
    function ucFirst(arr) {
        let newArr = [];
        for (let i = 0; i < arr.length; i++) {
            newArr[i] = arr[i].substr(0, 1).toUpperCase() + arr[i].substr(1);
        }
        return newArr;
    }
    
    function getString(arr) {
        let str = arr.join(' '); // Не забываем объявить переменную, так как в этой функции она ещё не была объявлена и не передавалась через параметры функции.
        return str;
    }
    <input type="text" class="input">

    • 1
  2. Best Answer
    Stepan Kasyanenko
    2020-02-03T16:22:15Z2020-02-03T16:22:15Z

    错误在input.addEventListener('blur', changeFirstSymbol);. 关键是您没有将changeFirstSymbol参数传递给函数。

    请参阅一个工作示例。

    let inputs = document.querySelectorAll('.input,.second-input');
    console.log(inputs.length);
    for (let i = 0; i < inputs.length; i++) {
      inputs[i].addEventListener('blur', function() {
        const result = changeFirstSymbol(inputs[i].value);
        console.log(result); // выводим результат в консоль
      });
    }
    
    function changeFirstSymbol(str) {
      const array = getArrayFromString(str);
      const arrayUCFirst = ucFirstArray(array);
      return getString(arrayUCFirst);
    }
    
    function ucFirstString(str) {
      return str.substr(0, 1).toUpperCase() + str.substr(1);
    }
    
    function getArrayFromString(str) {
      return str.split(' ');
    }
    
    function ucFirstArray(arr) {
      const newArr = [];
      for (let i = 0; i < arr.length; i++) {
        const str = ucFirstString(arr[i]);
        newArr.push(str);
      }
      return newArr;
    }
    
    function getString(arr) {
      return arr.join(' ');
    }
    <input type="text" class="input">
    <input type="text" class="second-input">

    • 1

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    如何从列表中打印最大元素(str 类型)的长度?

    • 2 个回答
  • Marko Smith

    如何在 PyQT5 中清除 QFrame 的内容

    • 1 个回答
  • Marko Smith

    如何将具有特定字符的字符串拆分为两个不同的列表?

    • 2 个回答
  • Marko Smith

    导航栏活动元素

    • 1 个回答
  • Marko Smith

    是否可以将文本放入数组中?[关闭]

    • 1 个回答
  • Marko Smith

    如何一次用多个分隔符拆分字符串?

    • 1 个回答
  • Marko Smith

    如何通过 ClassPath 创建 InputStream?

    • 2 个回答
  • Marko Smith

    在一个查询中连接多个表

    • 1 个回答
  • Marko Smith

    对列表列表中的所有值求和

    • 3 个回答
  • Marko Smith

    如何对齐 string.Format 中的列?

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5