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

Nie działająca pętla JavaScript

Aruba Cloud VPS - 50% taniej przez 3 miesiące!
+1 głos
596 wizyt
pytanie zadane 1 maja 2021 w JavaScript przez mialbiaek Użytkownik (510 p.)
function funkcja()
{
	var pierwsze_slowo, x;
	
	pierwsze_slowo = document.getElementById('pole1').value;
	
	for(x=1; x<=9; x++)
	{
		document.getElementById('div_wynik').innerHTML=pierwsze_slowo.charAt(x);
	}
}

Zwraca wynik jednej litery słowa... Chciałbym, żeby zwracało po kolei abcdef... (zależy jakie słowo)

komentarz 1 maja 2021 przez ScriptyChris Mędrzec (190,190 p.)

Czy nie lepiej zamiast pętli użyć tutaj metody slice?

komentarz 2 maja 2021 przez mialbiaek Użytkownik (510 p.)
W tym przypadku co planuję to rzeczywiście racja :D

2 odpowiedzi

+4 głosów
odpowiedź 1 maja 2021 przez Comandeer Guru (606,240 p.)
wybrane 2 maja 2021 przez mialbiaek
 
Najlepsza

Jeśli ma to wyświetlać pierwsze 9 liter, to nie zadziała, bo przy każdym przelocie pętli nadpisujesz zawartość elementu #div_wynik. Zamiast operatora = użyj operatora +=, dzięki czemu kolejne litery będą dodawane do tego elementu.

0 głosów
odpowiedź 3 maja 2021 przez VBService Ekspert (256,320 p.)
edycja 3 maja 2021 przez VBService

Możesz także użyć: substring()

<input type="text" id="pole1" value="Lorem ipsum dolor sit">
<div id="div_wynik_1"></div>
<div id="div_wynik_2"></div>
window.onload = () => {
  pierwszeSlowo();
}

function pierwszeSlowo()
{
  const pierwsze_slowo = document.getElementById('pole1').value.trim();

  if (pierwsze_slowo.length)
  {
    document.getElementById('div_wynik_1').textContent = pierwsze_slowo.substring(1, 10);
    for (let x=1; x<=9; x++)
    {
      document.getElementById('div_wynik_2').textContent += pierwsze_slowo[x];
    }    
  }
}

 

string.charAt(x) or string[x]? ]

1
komentarz 3 maja 2021 przez mialbiaek Użytkownik (510 p.)

@ScriptyChris @Comandeer @VBService Zrobiłem w ten sposób. Zdaję sobie sprawę z tego, że można by było to zrobić lepiej/krócej, ale potrzebuję póki co znajomości JavaScript na podstawowym poziomie. Dziękuję wam za pomoc. 

<!DOCTYPE html>
<html lang="pl">
<head>
	 <meta charset="utf-8"/>
	 <script src="scripts.js"></script>
</head>
<body>

	<form>
		<input type="text" maxlength="10" id="pole1"/><br>
		<input type="text" maxlength="10" id="pole2"/><br>
		<input type="button" value="ZAMIEŃ" id="przycisk" onclick="funkcja()"/>
	</form>
	<div id="div_result"></div>

</body>
</html>
function funkcja()
{
	var pierwsze_slowo, drugie_slowo, wyciete1_1, wyciete1_2, wyciete2_1, wyciete2_2;

	
	pierwsze_slowo = document.getElementById('pole1').value;
	drugie_slowo = document.getElementById('pole2').value;
	
	wyciete1_1 = pierwsze_slowo.slice(0, 1);
	wyciete1_2 = pierwsze_slowo.slice(1, 10);
	wyciete2_1 = drugie_slowo.slice(0, 1);
	wyciete2_2 = drugie_slowo.slice(1, 10);
	
	document.getElementById('div_result').innerHTML= wyciete1_1+wyciete2_2+' '+wyciete2_1+wyciete1_2;

}

 

komentarz 3 maja 2021 przez VBService Ekspert (256,320 p.)

... potrzebuję póki co znajomości JavaScript na podstawowym poziomie.

Można tekst do wypisania, formatować też tak (to nie jest "zaawansowany" poziom), dzięki czemu unikasz stosowania tylu zmiennych.

unction funkcja()
{
  const pierwsze_slowo = document.getElementById('pole1').value;
  const drugie_slowo = document.getElementById('pole2').value;

  document.getElementById('div_result').innerHTML = pierwsze_slowo.slice(0, 1)
                                                  + drugie_slowo.slice(1, 10) + ' '
                                                  + drugie_slowo.slice(0, 1)
                                                  + pierwsze_slowo.slice(1, 10);
}

 

komentarz 3 maja 2021 przez Comandeer Guru (606,240 p.)
No można, ale co jest złego w kilku zmiennych więcej? Tym bardziej, że akurat w tym wypadku IMO podnoszą czytelność.

Podobne pytania

+1 głos
1 odpowiedź 150 wizyt
pytanie zadane 13 maja 2016 w C i C++ przez kistel66 Początkujący (370 p.)
0 głosów
2 odpowiedzi 256 wizyt
pytanie zadane 30 grudnia 2017 w JavaScript przez Sandwitch Użytkownik (630 p.)
0 głosów
2 odpowiedzi 427 wizyt
pytanie zadane 29 grudnia 2020 w JavaScript przez Grzegorzko Obywatel (1,110 p.)

93,182 zapytań

142,196 odpowiedzi

322,002 komentarzy

62,513 pasjonatów

Advent of Code 2024

Top 15 użytkowników

  1. 2127p. - dia-Chann
  2. 2092p. - Łukasz Piwowar
  3. 2079p. - Łukasz Eckert
  4. 2037p. - Tomasz Bielak
  5. 2006p. - rucin93
  6. 2005p. - Łukasz Siedlecki
  7. 1964p. - CC PL
  8. 1785p. - Michal Drewniak
  9. 1744p. - rafalszastok
  10. 1724p. - Adrian Wieprzkowicz
  11. 1684p. - Mikbac
  12. 1624p. - Anonim 3619784
  13. 1520p. - Marcin Putra
  14. 1480p. - ssynowiec
  15. 1365p. - Dawid128
Szczegóły i pełne wyniki

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!

...