Endre størrelse på et vindu kan virke som en ubetydelig oppgave i nettutvikling, men det knytter faktisk en del konsepter fra JavaScript og Typescript, og spiller en avgjørende rolle for å sikre en responsiv og brukervennlig design. I sammenheng med et dynamisk brukergrensesnitt/UX, er funksjonen 'endre størrelse på vindu' avgjørende. Daglige eksempler kan inkludere en sidefelt som krymper ved endring av vinduets størrelse for å gi en sømløs leseplass, eller et galleribilde som justerer seg selv for å forhindre forvrengning. Modifikasjonen gjøres reaktivt ved å lytte etter en hendelse for endring av vinduet.
Problemet er å utføre en handling som er betinget av å endre størrelse på vinduer, dette kan håndteres med Typescript og DOM-manipulasjon veldig kortfattet. Vi vil utnytte Typescripts typekontroll og skalerbarhet for å organisere løsningen vår.
window.addEventListener('endre størrelse', () => {
la width = window.innerWidth;
if(width <= 768){// handling som skal utføres når vindusstørrelsen er mindre enn eller lik 768px }else{ // handling som skal utføres når vindusstørrelsen er større enn 768px } }); [/kode]
Forstå koden
Den oppgitte koden fungerer ved å umiddelbart påkalle en anonym funksjon hver gang vinduet endres. Denne anonyme funksjonen gir oss tilgang til hendelsesobjektet, som inneholder verdifull informasjon om "endre størrelse"-hendelsen. Inne i funksjonen definerer vi to forhold; en for når vinduets indre bredde er mindre enn eller lik 768 piksler og en annen for når den er mer enn det. Dette skillet brukes vanligvis for å skille mellom mobile og stasjonære enheter.
Evolusjon av vinduets størrelse
Window Resizing er et produkt av den utviklede verdenen av responsiv webdesign. I motsetning til tidligere dager da nettsteder ble bygget for standard skjermstørrelser, har dagens krav endret seg monumentalt. Med et unektelig bredt utvalg av enheter med varierte skjermoppløsninger, er det avgjørende at designet vårt tilpasser seg de individuelle visningsplattformene, og tilbyr en optimalisert og lettvint layout.
Javascript Events og Typescript
For å gå tilbake til løsningen vår, den viktigste delen her er å forstå hvordan du bruker JavaScript-hendelser med Typescript. «Endre størrelse»-hendelsen er bare en av de mange hendelsene som JavaScript gir for å bestemme forskjellige tilstander og handlinger på en nettside. 'klikk', 'sveve', 'musened' er noen eksempler. Koble disse hendelsene med Typescript lar utviklere lage renere, vedlikeholdbar kode med de sterke skriving av Typescript og fleksibiliteten til JavaScript.
Debouncing for effektivitet
Et siste poeng å vurdere er at «endre størrelse»-hendelsen utløses kontinuerlig, så lenge vinduet dras. Dette kan bety et kritisk treff på ytelsen hvis aktivitetslytterfunksjonen din er tung. For å lindre dette bruker vi et konsept som heter 'Debouncing'. Debouncing i JavaScript er en praksis som brukes for å begrense tiden mellom påkallinger av en funksjon. Her er et eksempel på hvordan vi kan debounce vår resize-funksjon.
la debounceTimeout;
window.addEventListener('endre størrelse', () => {
clearTimeout(debounceTimeout);
debounceTimeout = setTimeout(() => {
la width = window.innerWidth;
if(width <= 768){// handling som skal utføres når vindusstørrelsen er mindre enn eller lik 768px }else{ // handling som skal utføres når vindusstørrelsen er større enn 768px } }, 100); }); [/code] Det handler om det. Når forklaringen er fullført, skal det nå være enkelt å forstå og implementere funksjoner som å endre størrelse på vinduer med JavaScript og Typescript. Lykke til med koding!