Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [JavaScript]automatyczne przepisywanie znakow
pakolord
post 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 questionmark.gif 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
Go to the top of the page
+Quote Post
nospor
post 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

Go to the top of the page
+Quote Post
Comandeer
post 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" biggrin.gif

@pakolord polecam sprawdzić zdarzenie input, bo właśnie do takich rzeczy powstało. Ale i tak pokaż kod wink.gif


--------------------
Go to the top of the page
+Quote Post
pakolord
post 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
  1. <input type="text" name="abc" id="abc" />
  2.  
  3. <script type="text/javascript">
  4.  
  5. var abc = document.getElementById('abc').value;
  6. document.getElementById('abc').onchange = document.write(abc);
  7.  
  8.  


Wyczytalem aby cala akcja wykonywala sie bez przeładowania strony, nalezy skorzystac z AJAX czy moge to ominac questionmark.gif

Ten post edytował pakolord 16.07.2015, 14:41:34
Go to the top of the page
+Quote Post
Skie
post 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.
Go to the top of the page
+Quote Post
Comandeer
post 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 addEventListenerhttps://developer.mozilla.org/en-US/docs/We...ddEventListener


--------------------
Go to the top of the page
+Quote Post
kafowi
post 16.07.2015, 16:03:10
Post #7





Grupa: Zarejestrowani
Postów: 75
Pomógł: 20
Dołączył: 13.02.2015

Ostrzeżenie: (0%)
-----


Cytat(Skie @ 16.07.2015, 16:17:11 ) *
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.
Go to the top of the page
+Quote Post
kapslokk
post 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 smile.gif
Go to the top of the page
+Quote Post
kafowi
post 16.07.2015, 17:04:15
Post #9





Grupa: Zarejestrowani
Postów: 75
Pomógł: 20
Dołączył: 13.02.2015

Ostrzeżenie: (0%)
-----


Cytat(kapslokk @ 16.07.2015, 17:12:33 ) *
Ja bym zrobił zamiast onkeyup: oninput
Dlatego, że w przypadku onkeyup nie możemy np. zrobić ctrl+a, a później backspace smile.gif

Sprawdzałeś? bo mnie działa bez zarzutu. Myślę, że chodziło o użycie onkeypress albo onkeydown.
Go to the top of the page
+Quote Post
kapslokk
post 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 smile.gif

@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
Go to the top of the page
+Quote Post
Comandeer
post 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


--------------------
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Wersja Lo-Fi Aktualny czas: 24.04.2024 - 17:08