$(document).ready(adjustEvents);
$(window).on('resize orientationchange', adjustEvents);
function adjustEvents() {
var ww = document.body.clientWidth,
vis = ww > 1030 ? 5 : (ww >= 768 ? 3 : 1);
$('.cycle').cycle({
fx : 'carousel',
swipe : true,
timeout : 5000,
slides : '> article',
carouselVisible : vis,
carouselFluid : true,
autoHeight : 'calc',
prev : '#prev',
next : '#next'
});
}
Come posso convertire questo jQuery disordinato per essere meno gonfio e reattivo
-
29-07-2022 - |
Domanda
Sto usando JQuery Cycle2 e il plug -in Carousel per visualizzare alcuni eventi sul mio sito. Tutto funziona alla grande, ma voglio che l'opzione visibile cambi da 5 a 3 su tablet (tra 768px e 1030px) e poi fino a 1 su telefoni (meno di 768px). Tutte le altre opzioni possono rimanere le stesse. Questo codice è violato insieme e disordinato, quindi sto cercando un modo migliore per farlo. Inoltre, attualmente funziona solo al momento dell'aggiornamento. Va bene, ma sarebbe bello se ricaricasse e funzionasse in tempo reale quando si ridimensiona. Ecco il mio codice attuale:
// Events
var ww = document.body.clientWidth;
$(document).ready(function() {
adjustEvents();
})
$(window).bind('resize orientationchange', function() {
ww = document.body.clientWidth;
adjustEvents();
});
var adjustEvents = function() {
if (ww > 1030) {
$('.cycle').cycle({
fx:'carousel',
swipe:true,
timeout:5000,
slides:'> article',
carouselVisible:5,
carouselFluid:true,
autoHeight:'calc',
prev:'#prev',
next:'#next'
});
}
else if (ww >= 768) {
$('.cycle').cycle({
fx:'carousel',
swipe:true,
timeout:5000,
slides:'> article',
carouselVisible:3,
carouselFluid:true,
autoHeight:'calc',
prev:'#prev',
next:'#next'
});
}
else if (ww < 768) {
$('.cycle').cycle({
fx:'carousel',
swipe:true,
timeout:5000,
slides:'> article',
carouselVisible:1,
carouselFluid:true,
autoHeight:'calc',
prev:'#prev',
next:'#next'
});
}
}
Soluzione
Altri suggerimenti
Ecco una versione "tagliata" del codice ...
// Events
var ww = document.body.clientWidth;
$(document).ready(function() {
adjustEvents();
})
$(window).bind('resize orientationchange', function() {
ww = document.body.clientWidth;
adjustEvents();
});
var adjustEvents = function() {
var options = {
fx:'carousel',
swipe:true,
timeout:5000,
slides:'> article',
carouselFluid:true,
autoHeight:'calc',
prev:'#prev',
next:'#next'
}
if (ww > 1030) {
options.carouselVisible = 5;
}
else if (ww >= 768) {
options.carouselVisible = 3;
}
else if (ww < 768) {
options.carouselVisible = 1;
}
$('.cycle').cycle(options);
}
Tutto quello che ho fatto è stato creare una variabile per archiviare le opzioni di ciclo e cambiare solo la proprietà 1 rilevante per ogni larghezza.