Jump to content

SUBIECTE NOI
« 1 / 5 »
RSS
Samsung S24 plus

Imi iau un Dell? (Vostro vs others)

Abonati Qobuz?

transport -tren
 Platforma electronica de eviden&#...

Cot cu talpa montat stramb in per...

Sfat achizitie sistem audio pentr...

tavan fals rigips
 Ce preferați: produse mai scumpe ...

Demagnetizare (minimala) ori ba?

Cum pot sa vad pe un proiector pr...

Joc Drone
 Dropshipping

Sfat achizitie AC Gree Fairy vs P...

MONITOR LG fara sonor !

Batalia pentru Bucuresti - ND, Fi...
 

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,950
  • Î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,950
  • Înscris: 24.04.2013

Quote

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

Anunturi

Chirurgia endoscopică a hipofizei Chirurgia endoscopică a hipofizei

"Standardul de aur" în chirurgia hipofizară îl reprezintă endoscopia transnazală transsfenoidală.

Echipa NeuroHope este antrenată în unul din cele mai mari centre de chirurgie a hipofizei din Europa, Spitalul Foch din Paris, centrul în care a fost introdus pentru prima dată endoscopul în chirurgia transnazală a hipofizei, de către neurochirurgul francez Guiot. Pe lângă tumorile cu origine hipofizară, prin tehnicile endoscopice transnazale pot fi abordate numeroase alte patologii neurochirurgicale.

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