[JavaScript]automatyczne przepisywanie znakow |
[JavaScript]automatyczne przepisywanie znakow |
16.07.2015, 13:38:23
Post
#1
|
|
Grupa: Zarejestrowani Postów: 82 Pomógł: 0 Dołączył: 27.02.2014 Ostrzeżenie: (0%) |
Witam, ucze sie js i narazie nie wszystko jest mi jasne, czy ktos moglby mi powiedziec jak ulozyc funkcje tak aby pisane znaki w jednym oknie tekstowym byly na bierzaco przepisywane do drugiego okna badz diva bez odswiezania strone cos na zasadzie http://jsbin.com . Probowalem z onchange itd ale cos niebardzo mi wychodzi.
Ten post edytował pakolord 16.07.2015, 15:14:41 |
|
|
16.07.2015, 13:39:55
Post
#2
|
|
Grupa: Moderatorzy Postów: 36 455 Pomógł: 6292 Dołączył: 27.12.2004 |
Co do kodu to pokaz co stworzyles -------------------- "Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista "Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer |
|
|
16.07.2015, 14:00:54
Post
#3
|
|
Grupa: Zarejestrowani Postów: 1 268 Pomógł: 254 Dołączył: 11.06.2009 Skąd: Świętochłowice Ostrzeżenie: (0%) |
@nospor czekam na wersję tego obrazka z cytatem stulecia z Heliona: "Java ma się do JavaScript jak szynka do hamburgera"
@pakolord polecam sprawdzić zdarzenie input, bo właśnie do takich rzeczy powstało. Ale i tak pokaż kod -------------------- ★Mój blog || Okiem krytyka★
|
|
|
16.07.2015, 14:13:26
Post
#4
|
|
Grupa: Zarejestrowani Postów: 82 Pomógł: 0 Dołączył: 27.02.2014 Ostrzeżenie: (0%) |
Jak pisalem dopiero sie ucze wiec narazie sam jestem w stanie napisac cos takiego ale wyswietla mi value dopiero po odswiezeniu strony
Wyczytalem aby cala akcja wykonywala sie bez przeładowania strony, nalezy skorzystac z AJAX czy moge to ominac Ten post edytował pakolord 16.07.2015, 14:41:34 |
|
|
16.07.2015, 15:17:11
Post
#5
|
|
Grupa: Zarejestrowani Postów: 555 Pomógł: 84 Dołączył: 20.02.2008 Skąd: Małopolska Ostrzeżenie: (0%) |
Twój JS wykonuje się zaraz po wczytaniu strony, dokładnie jeden raz. W 5 linii, pobierasz wartość inputa, która w tym momencie zależnie od przeglądarki będzie pustym stringiem lub undefined. Zapisujesz tę wartośc, a następnie w linii 6 ustawiasz handlera zdarzenia onchange na funkcję która podmieni zawartość strony na zawartość tej zmiennej - czyli wyświetli Ci się pusta strona i wydaje Ci się , że się ona przeładowała. Nie powinieneś używać document.write!
Kod powinien wyglądać tak: Kod document.getElementById('id1').onchange = function() { var value = this.value; var output = document.getElementById('id2'); output.value = value; }; Przypisujesz na onchange funkcje, która przy każdej zmianie pobiera wartość inputa o id=id1 i wpisuje jego wartość do inputa o id=id2. 'this' wykorzystane w środku funkcji odnosi się do elementu, na którym się wykonał handler - czyli input o id=id1. -------------------- Wieloprocesowość i wielowątkowość w PHP, poznaj Kraken PHP!
Serwer HTTP i WebSocket w PHP | Promise/A+ Strona Domowa | Elradia MMORPG FireFox: make the web better. |
|
|
16.07.2015, 15:38:50
Post
#6
|
|
Grupa: Zarejestrowani Postów: 1 268 Pomógł: 254 Dołączył: 11.06.2009 Skąd: Świętochłowice Ostrzeżenie: (0%) |
Osobiście zmieniłbym onchange na oninput - onchange odpali się dopiero po kliknięciu poza polem, w którym piszemy. No i mimo wszystko lepiej eventy przypinać przez addEventListener → https://developer.mozilla.org/en-US/docs/We...ddEventListener
-------------------- ★Mój blog || Okiem krytyka★
|
|
|
16.07.2015, 16:03:10
Post
#7
|
|
Grupa: Zarejestrowani Postów: 75 Pomógł: 20 Dołączył: 13.02.2015 Ostrzeżenie: (0%) |
Twój JS wykonuje się zaraz po wczytaniu strony, dokładnie jeden raz. W 5 linii, pobierasz wartość inputa, która w tym momencie zależnie od przeglądarki będzie pustym stringiem lub undefined. Zapisujesz tę wartośc, a następnie w linii 6 ustawiasz handlera zdarzenia onchange na funkcję która podmieni zawartość strony na zawartość tej zmiennej - czyli wyświetli Ci się pusta strona i wydaje Ci się , że się ona przeładowała. Nie powinieneś używać document.write! Kod powinien wyglądać tak: Kod document.getElementById('id1').onchange = function() { var value = this.value; var output = document.getElementById('id2'); output.value = value; }; Przypisujesz na onchange funkcje, która przy każdej zmianie pobiera wartość inputa o id=id1 i wpisuje jego wartość do inputa o id=id2. 'this' wykorzystane w środku funkcji odnosi się do elementu, na którym się wykonał handler - czyli input o id=id1. Ja bym to zrobił tak: - http://jsfiddle.net/kafowi/zcfjavn5/2/ Nie trzeba klikać poza input by się zaktualizowało. |
|
|
16.07.2015, 16:12:33
Post
#8
|
|
Grupa: Zarejestrowani Postów: 965 Pomógł: 285 Dołączył: 19.06.2015 Skąd: Warszawa Ostrzeżenie: (0%) |
Ja bym zrobił zamiast onkeyup: oninput
Dlatego, że w przypadku onkeyup nie możemy np. zrobić ctrl+a, a później backspace |
|
|
16.07.2015, 17:04:15
Post
#9
|
|
Grupa: Zarejestrowani Postów: 75 Pomógł: 20 Dołączył: 13.02.2015 Ostrzeżenie: (0%) |
|
|
|
16.07.2015, 17:25:05
Post
#10
|
|
Grupa: Zarejestrowani Postów: 965 Pomógł: 285 Dołączył: 19.06.2015 Skąd: Warszawa Ostrzeżenie: (0%) |
Zdecydowanie sprawdzałem i u mnie na ff 39.0 nie bangla, stąd też mój post
@edit Sprawdziłem z ciekawości na drugim komputerze i tam wszystko jest ok. Być może ten konkretny ma z tym jakiś problem. Sorry za zamieszanie. Ten post edytował kapslokk 16.07.2015, 17:31:14 |
|
|
16.07.2015, 18:44:11
Post
#11
|
|
Grupa: Zarejestrowani Postów: 1 268 Pomógł: 254 Dołączył: 11.06.2009 Skąd: Świętochłowice Ostrzeżenie: (0%) |
Ale do obsługi inputów jest input. Przy keyup można się nadziać na kilka różnych rzeczy typu brak obsługi wklejania z poziomu menu kontekstowego: http://jsfiddle.net/Comandeer/1kn9kh0z/
Używajmy odpowiednich zdarzeń jeśli jest taka możliwość. key… są do obsługi klawiatury (np w apkach), do obsługi pól formularza są inne, lepsze eventy -------------------- ★Mój blog || Okiem krytyka★
|
|
|
Wersja Lo-Fi | Aktualny czas: 24.04.2024 - 17:08 |