144 lines
10 KiB
Markdown
144 lines
10 KiB
Markdown
![]() |
---
|
|||
|
title: Title Case a Sentence
|
|||
|
localeTitle: Название Случайное предложение
|
|||
|
---
|
|||
|
 Не забудьте использовать **`Read-Search-Ask`** если вы застряли. Попробуйте подключить программу  и напишите свой собственный код 
|
|||
|
|
|||
|
###  Проблема Объяснение:
|
|||
|
|
|||
|
Мы должны вернуть предложение с титульным листом. Это означает, что первая буква всегда будет в верхнем регистре, а остальные будут в нижнем регистре.
|
|||
|
|
|||
|
#### Связанные ссылки
|
|||
|
|
|||
|
* [Глобальный объект String](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String)
|
|||
|
* [JS String Prototype ToLowerCase](http://forum.freecodecamp.com/t/javascript-string-prototype-tolowercase/15948)
|
|||
|
* [JS String Prototype ToUpperCase](http://forum.freecodecamp.com/t/javascript-string-prototype-touppercase/15950)
|
|||
|
* [Замена прототипа JS](http://forum.freecodecamp.com/t/javascript-string-prototype-replace/15942)
|
|||
|
|
|||
|
##  Подсказка: 1
|
|||
|
|
|||
|
* Вы должны начать с разделения строки на массив слов.
|
|||
|
* Разделите предложение.
|
|||
|
|
|||
|
> _попытаться решить проблему сейчас_
|
|||
|
|
|||
|
##  Подсказка: 2
|
|||
|
|
|||
|
* Вы должны сделать слово в нижнем регистре, прежде чем делать первую букву в верхнем регистре.
|
|||
|
* Используйте метод замены для каждого слова, чтобы загладить первую букву каждого слова.
|
|||
|
|
|||
|
> _попытаться решить проблему сейчас_
|
|||
|
|
|||
|
##  Подсказка: 3
|
|||
|
|
|||
|
* Вам нужно будет создать новую строку с фрагментами предыдущего и в конце снова объединить все в одну строку.
|
|||
|
* В методе замены дайте первый аргумент как позицию первой буквы, используя charAt. Для второго аргумента напишите функцию, чтобы вернуть заглавную букву в качестве замены.
|
|||
|
|
|||
|
> _попытаться решить проблему сейчас_
|
|||
|
|
|||
|
## Осторожно, спойлеры!
|
|||
|
|
|||
|

|
|||
|
|
|||
|
**Решение впереди!**
|
|||
|
|
|||
|
##  Решение базового кода:
|
|||
|
```
|
|||
|
String.prototype.replaceAt = function(index, character) {
|
|||
|
return this.substr(0, index) + character + this.substr(index+character.length);
|
|||
|
};
|
|||
|
|
|||
|
function titleCase(str) {
|
|||
|
var newTitle = str.split(' ');
|
|||
|
var updatedTitle = [];
|
|||
|
for (var st in newTitle) {
|
|||
|
updatedTitle[st] = newTitle[st].toLowerCase().replaceAt(0, newTitle[st].charAt(0).toUpperCase());
|
|||
|
}
|
|||
|
return updatedTitle.join(' ');
|
|||
|
}
|
|||
|
```
|
|||
|
|
|||
|
 [Код запуска](https://repl.it/CLjU/8)
|
|||
|
|
|||
|
### Код Объяснение:
|
|||
|
|
|||
|
Мы модифицируем функцию `replaceAt` с использованием прототипа, чтобы облегчить использование программы.
|
|||
|
|
|||
|
Разделите строку пробелами и создайте переменную для отслеживания обновленного заголовка. Затем мы используем цикл для поворота первого символа слова в верхний регистр, а остальные - в нижний регистр. создавая конкатенированную строку, состоящую из всего слова в нижнем регистре, причем первый символ заменяется на верхний.
|
|||
|
|
|||
|
#### Связанные ссылки
|
|||
|
|
|||
|
* [JS для пояснений](http://forum.freecodecamp.com/t/javascript-for-loop/14666s-Explained)
|
|||
|
* [Разделение прототипа JS String](http://forum.freecodecamp.com/t/javascript-string-prototype-split/15944)
|
|||
|
* [JS String Prototype Substr](http://forum.freecodecamp.com/t/javascript-string-prototype-substr/15945)
|
|||
|
* [Присоединиться](http://forum.freecodecamp.com/t/javascript-array-prototype-join/14292)
|
|||
|
|
|||
|
##  Решение промежуточного кода:
|
|||
|
```
|
|||
|
function titleCase(str) {
|
|||
|
var convertToArray = str.toLowerCase().split(" ");
|
|||
|
var result = convertToArray.map(function(val){
|
|||
|
return val.replace(val.charAt(0), val.charAt(0).toUpperCase());
|
|||
|
});
|
|||
|
return result.join(" ");
|
|||
|
}
|
|||
|
|
|||
|
titleCase("I'm a little tea pot");
|
|||
|
```
|
|||
|
|
|||
|
 [Код запуска](https://repl.it/CLjU/9)
|
|||
|
|
|||
|
### Код Объяснение:
|
|||
|
|
|||
|
Мы делаем всю строчную строчную строчку, а затем преобразуем ее в массив. Затем мы используем функцию карты, чтобы заменить символ нижнего регистра верхним регистром. Наконец, мы возвращаем строку, используя метод `join` .
|
|||
|
|
|||
|
#### Связанные ссылки
|
|||
|
|
|||
|
* [Карта прототипа JS Array](http://forum.freecodecamp.com/t/javascript-array-prototype-map/14294)
|
|||
|
|
|||
|
##  Расширенное решение для кода:
|
|||
|
```
|
|||
|
function titleCase(str) {
|
|||
|
return str.toLowerCase().replace(/(^|\s)\S/g, (L) => L.toUpperCase());
|
|||
|
}
|
|||
|
```
|
|||
|
|
|||
|
 [Код запуска](https://repl.it/CLjU/14)
|
|||
|
|
|||
|
### Код Объяснение:
|
|||
|
|
|||
|
Решение работает, сначала уменьшая все символы в строке, а затем только верхний индекс первого символа каждого слова.
|
|||
|
|
|||
|
* `str.toLowerCase()` цепочку с помощью `str.toLowerCase()` .
|
|||
|
|
|||
|
* Замените каждое слово «первый символ» на верхний регистр, используя `.replace` .
|
|||
|
|
|||
|
* Поиск символа в начале каждого слова, т.е. сопоставление любого символа, следующего за `space` или совпадающего с первым символом всей строки, с использованием следующего шаблона.
|
|||
|
|
|||
|
* Объяснение Regex:
|
|||
|
|
|||
|
* Найти все символы без пробелов `(\S` )
|
|||
|
|
|||
|
* В начале строки `(^)`
|
|||
|
|
|||
|
* Или после любого символа пробела `(\s)`
|
|||
|
|
|||
|
* Модификатор `g` ищет другой такой шаблон слова во всей строке и заменяет их.
|
|||
|
|
|||
|
* Это решение работает с национальными символами и акцентированными буквами, как показано на следующих примерах
|
|||
|
`international characters:` 'бабушка курит трубку' // -> 'Бабушка Курит Трубку'
|
|||
|
`accented characters:` 'località àtilacol' // -> 'Località Àtilacol'
|
|||
|
|
|||
|
|
|||
|
#### Связанные ссылки
|
|||
|
|
|||
|
* [Ресурсы JS Regex](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions)
|
|||
|
|
|||
|
##  ПРИМЕЧАНИЯ ДЛЯ ВЗНОСОВ:
|
|||
|
|
|||
|
*  **НЕ** добавляйте решения, похожие на любые существующие решения. Если вы считаете, что это **_похоже, но лучше_** , попробуйте объединить (или заменить) существующее подобное решение.
|
|||
|
* Добавьте объяснение своего решения.
|
|||
|
* Классифицируйте решение в одной из следующих категорий - **Basic** , **Intermediate** и **Advanced** . 
|
|||
|
* Пожалуйста, добавьте свое имя пользователя, только если вы добавили **соответствующее основное содержимое** . (  **_НЕ_** _удаляйте существующие имена пользователей_ )
|
|||
|
|
|||
|
> Увидеть  [**`Wiki Challenge Solution Template`**](http://forum.freecodecamp.com/t/algorithm-article-template/14272) для [**`Wiki Challenge Solution Template`**](http://forum.freecodecamp.com/t/algorithm-article-template/14272) для справки.
|