• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Problem ze zmiana pierwszych liter wyrazów na wielkie w stringu Javascript

Aruba Cloud VPS - 50% taniej przez 3 miesiące!
0 głosów
4,284 wizyt
pytanie zadane 18 września 2017 w JavaScript przez avrack4 Początkujący (370 p.)

Dzień dobry.

Celem mojego kodu jest zmiana pierwszych liter wyrazów  podanego stringa na wielkie.

Czy mógłby mi ktoś wytłumaczyć dlaczego to nie działa?
 

        function titleCase(str) {
              var arr = str.split(" ");
              for (var i = 0; i < arr.length; i++){
                  for (var x = 0; x < 1; x++){
                      arr[i][x].toUpperCase;
                      console.log("indeks :"+x+" wartość: "+arr[i][x]);
                  }
              }
              return str;
        }

            titleCase("Jakiś dłuższy przykładowy tekst");


Wyszedłem z zalozenia, ze skoro string jest tablicą znakow to na kazdym osobno takze mozna bedzie dokonywac operacji. Skoro konsola loguje kazda z liter normalnie to dlaczego nie działa na nich metoda toUpperCase?.

Nie rozumiem dlaczego przypisując wraz z metodą toUpperCase  każdą z arr[i][x] do jakiejs zmiennej wszystko działa poprawnie a osobno nie.  

var y = arr[i][x].toUpperCase();
console.log(y);

 

Wiem ,że jest to wynik mojego niedoinformowania w kwestii stringów i tablic ale szukam od 2 dni w internecie rozwiązania i nie potrafię się z tym uporać.

Dziękuję z góry za pomoc.

2
komentarz 18 września 2017 przez cyklop123 Bywalec (2,790 p.)
Bo toUpperCase nie zmienia w podanym ciągu tylko zwraca zmieniony ciąg, a ty musisz go gdzieś przypisać. W tym wypadku w to samo miejsce

3 odpowiedzi

+1 głos
odpowiedź 18 września 2017 przez cyklop123 Bywalec (2,790 p.)

Bo zwracasz nieprzetworzony string.

Zrób tak.

function titleCase(str) {
      var arr = str.split(" ");
      for (var i = 0; i < arr.length; i++){
         arr[i] = arr[i].split("");
         arr[i][0] = arr[i][0].toUpperCase();
         arr[i] = arr[i].join("");
        }
      return arr.join(" ");
}
 
    titleCase("Jakiś dłuższy przykładowy tekst");

Może metoda troszkę upośledzona ale działa

+1 głos
odpowiedź 18 września 2017 przez Chess Szeryf (76,710 p.)
edycja 18 września 2017 przez Chess
function titleCase(str) {
     var a = str.split(" ");
	 
	 for(var i=0;i<a.length;i++){
		 
		// console.log(a[0].replace(a[0][0],a[0][0].toUpperCase()));
		// console.log(a[1].replace(a[1][0],a[1][0].toUpperCase()));
		// console.log(a[2].replace(a[2][0],a[2][0].toUpperCase()));
		a[i] = a[i].replace(a[i][0],a[i][0].toUpperCase());
	}
	return a.join(" ");
}
console.log( titleCase("lorem ipsum, ipsum lorem, lorem ipsum(...)"));

Edit: Skorzystałem z return arr.join(" "); po odpowiedzi @cyklop123.

+1 głos
odpowiedź 18 września 2017 przez avrack4 Początkujący (370 p.)
Kochani dziękuję wszystkim za odpowiedzi.
Pod spodem przedstawiam skończony kod - może któremuś z forumowiczy w przyszłości się przyda.

funkcja przekształca stringi (bez względu na konfigurację wielkości liter) na taki, że w każdym wyrazie pierwsza litera jest wielka a pozostałe małe. :)

 function titleCase(str) {
              var arr = str.split(" ");
              for (var i = 0; i < arr.length; i++){
                  arr[i] = arr[i].split("");
                  for (var x = 0; x < 1; x++){
                   arr[i][x] = arr[i][x].toUpperCase();
                      console.log(arr);
                  }
                  for (var y = 1; y <arr[i].length; y++){
                   arr[i][y] = arr[i][y].toLowerCase();
                      console.log(arr);
                  }
                  arr[i] = arr[i].join("");
                  
              }
            arr = arr.join("  ");
              console.log(arr);
        }

            titleCase("Jakiś dłuŻszy PrzYkŁaDowy tekst");
3
komentarz 18 września 2017 przez E1 Obywatel (1,810 p.)
edycja 18 września 2017 przez E1

A teraz porównaj tą ścianę tekstu z pięknem functional programming: 

let titleCase = (str) => str.split(" ").map((str) => str = str.charAt(0).toUpperCase() + str.substring(1).toLowerCase()).join(" ");

console.log(titleCase("Jakiś dłuŻszy PrzYkŁaDowy tekst"));


Jest różnica, prawda? wink

Podobne pytania

0 głosów
1 odpowiedź 252 wizyt
+1 głos
1 odpowiedź 252 wizyt
pytanie zadane 9 maja 2019 w JavaScript przez aniaska4 Obywatel (1,010 p.)
0 głosów
4 odpowiedzi 3,297 wizyt
pytanie zadane 6 grudnia 2018 w JavaScript przez aniaska4 Obywatel (1,010 p.)

93,112 zapytań

142,092 odpowiedzi

321,636 komentarzy

62,453 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj

Wprowadzenie do ITsec, tom 1 Wprowadzenie do ITsec, tom 2

Można już zamawiać dwa tomy książek o ITsec pt. "Wprowadzenie do bezpieczeństwa IT" - mamy dla Was kod: pasja (użyjcie go w koszyku), dzięki któremu uzyskamy aż 15% zniżki! Dziękujemy ekipie Sekuraka za fajny rabat dla naszej Społeczności!

...