JavaScript/JQuery: (pencere)$.boyutlandırma tamamlandıktan SONRA yangın nasıl yeniden boyutlandırmak?
Bir WordPress kullanmak gibi: kullanıyorum
$(window).resize(function() { ... });
Ancak, eğer kişi elle daha büyük/daha küçük hale getirmek için pencere kenarına sürükleyerek tarayıcı pencereleri yeniden boyutlandırır, yukarıda .resize
olay birden çok kez yangın gibi görünüyor.
Soru:Nasıl ben arayıp tarayıcı penceresi yeniden boyutlandırmak tamamladıktan SONRA bir işlevi olay sadece bir kez tetiklenmesi ()?
CEVAP
İşte kod birden fazla yerde çağrılabilir CMS çözümü bir değişiklik:
var waitForFinalEvent = (function () {
var timers = {};
return function (callback, ms, uniqueId) {
if (!uniqueId) {
uniqueId = "Don't call this twice without a uniqueId";
}
if (timers[uniqueId]) {
clearTimeout (timers[uniqueId]);
}
timers[uniqueId] = setTimeout(callback, ms);
};
})();
Kullanımı:
$(window).resize(function () {
waitForFinalEvent(function(){
alert('Resize...');
//...
}, 500, "some unique string");
});
CMS çözümü iyi olursa sadece Ara bir kez, ama eğer bunu birden çok kez, örneğin eğer farklı parçaları kodunuzu ayarlamak ayrı geri aramaları için pencereyi yeniden boyutlandırmak, sonra başarısız b/c paylaştıkları timer
değişken.
Bu değişiklik ile, her bir geri arama için benzersiz bir kimlik sağlamak ve bu benzersiz Kimlikler her zaman aşımı olayları ayrı tutmak için kullanılır.
Nasıl yüklendikten sonra JavaScript il...
Çapraz tarayıcı penceresi yeniden boyu...
Nasıl jQuery DatePicker kontrol yenide...
Bu nasıl JavaScript/JQuery Sözdizimi i...
Nasıl JavaScript pencereyi yeniden boy...