Jump to content

SUBIECTE NOI
« 1 / 5 »
RSS
Incalzire casa fara gaz/lemne

Incalzire in pardoseala etapizata

Suprataxa card energie?!

Cum era nivelul de trai cam din a...
 probleme cu ochelarii

Impozite pe proprietati de anul v...

teava rezistenta panou apa calda

Acces in Curte din Drum National
 Sub mobila de bucatarie si sub fr...

Rezultat RMN

Numar circuite IPAT si prindere t...

Pareri brgimportchina.ro - teapa ...
 Lucruri inaintea vremurilor lor

Discuții despre TVR Sport HD.

Cost abonament clinica privata

Tremura toata, dar nu de la ro...
 

Rulare functie de mai multe ori cu javascript

- - - - -
  • Please log in to reply
7 replies to this topic

#1
alex05ok

alex05ok

    Member

  • Grup: Members
  • Posts: 376
  • Înscris: 08.11.2007
Buna ziua!

Cum fac ca functia "scrollWin" sa se ruleze de 100 de ori la o singura apasare de buton?

https://jsfiddle.net/k2og96ju/1/

Multumesc!

#2
whiteboy

whiteboy

    Member

  • Grup: Members
  • Posts: 927
  • Înscris: 18.12.2007
Nu stiu de ce ai face una ca asta, dar raspunsul e asta:
  var i;
  for (i = 0; i <= 100; i++) {
   window.scrollBy(0, 10);
  }


Eu as pune link pe div-ul necesar si as sari la partea de care am nevoie fara sa incarc aiurea pagina.
Sau, windows.scrollBy(0, 1000); pentru ca 100*10 = 1000, as evita acel loop propus.

#3
alex05ok

alex05ok

    Member

  • Grup: Members
  • Posts: 376
  • Înscris: 08.11.2007
Multumesc whiteboy, am uitat sa mentionez ca vreau o pauza de 100 ms dupa fiecare scroll. Cum fac asta?

#4
sags

sags

    Senior Member

  • Grup: Senior Members
  • Posts: 9,848
  • Înscris: 24.04.2013
Folosesti setInterval() si un contor pe care il initializezi cu numar de executii dorit. In functia execuata la intervalele de timp specificate, pe langa ca faci scroll decrementezi contorul si cand ajunge la 0 folosesti clearInterval() ca sa opresti apelurile.

#5
alex05ok

alex05ok

    Member

  • Grup: Members
  • Posts: 376
  • Înscris: 08.11.2007
Multumesc pentru ajutor, codul de care aveam nevoie este:

<body>
<button onclick="myFunction()">Try it</button>

<script>
var myVar;
function myFunction() {
myVar = setInterval(scrollWin, 100);
}
function scrollWin() {
window.scrollBy(0, 10);
}
</script>
</body>


Ca sa opresc codul dau refresh la pagina, nu mai folosesc loop.

Edited by alex05ok, 21 October 2019 - 09:37.


#6
whiteboy

whiteboy

    Member

  • Grup: Members
  • Posts: 927
  • Înscris: 18.12.2007
Functia asta va scrolla pana la sfarsitul paginii si nu vei mai putea da scroll up pentru ca nu ai folosit clearInterval().
Asta vrei tu?

#7
alex05ok

alex05ok

    Member

  • Grup: Members
  • Posts: 376
  • Înscris: 08.11.2007
Am adaugat acum si "clearInterval" pentru oprire, o sa atribui o tasta pentru butonul "Stop time".

<button onclick="myFunction()">Try it</button>
<button onclick="myStopFunction()">Stop time</button>

<script>
var myVar;
function myFunction() {
myVar = setInterval(scrollWin, 100);
}
function scrollWin() {
window.scrollBy(0, 10);
}
function myStopFunction() {
clearInterval(myVar);
}
</script>


Edited by alex05ok, 21 October 2019 - 10:21.


#8
sags

sags

    Senior Member

  • Grup: Senior Members
  • Posts: 9,848
  • Înscris: 24.04.2013

Quote

var myVar, myCounter;
function myFunction() {
    myCounter = 100;
    …
}
function scrollWin() {
    …
    if (!--myCounter) clearInterval(myVar);
}
Nu e mai simplu asa?

Anunturi

Second Opinion Second Opinion

Folosind serviciul second opinion ne puteți trimite RMN-uri, CT -uri, angiografii, fișiere .pdf, documente medicale.

Astfel vă vom putea da o opinie neurochirurgicală, fără ca aceasta să poată înlocui un consult de specialitate. Răspunsurile vor fi date prin e-mail în cel mai scurt timp posibil (de obicei în mai putin de 24 de ore, dar nu mai mult de 48 de ore). Second opinion – Neurohope este un serviciu gratuit.

www.neurohope.ro

0 user(s) are reading this topic

0 members, 0 guests, 0 anonymous users

Forumul Softpedia foloseste "cookies" pentru a imbunatati experienta utilizatorilor Accept
Pentru detalii si optiuni legate de cookies si datele personale, consultati Politica de utilizare cookies si Politica de confidentialitate