欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

jquery如何解決resize執(zhí)行兩次的問(wèn)題

 更新時(shí)間:2023年07月04日 14:07:45   作者:暖陽(yáng) (*◎v◎*)  
這篇文章主要介紹了jquery如何解決resize執(zhí)行兩次的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

jquery解決resize執(zhí)行兩次問(wèn)題

代碼如下(示例):

? ? // - 解決resize執(zhí)行兩次的問(wèn)題
? ? var n = 0;
? ? jQuery(window).resize(function () {
? ? ? n++;
? ? ? if (n % 2 == 0) {
? ? ? ? n = 0;
? ? ? ? //todo
? ? ? ? // console.log("todo");
? ? ? }
? ? ? // console.log(n);
? ? });

谷歌瀏覽器在測(cè)試時(shí),當(dāng)窗口發(fā)生改變時(shí),resize()函數(shù)有時(shí)會(huì)執(zhí)行一次,有時(shí)會(huì)執(zhí)行兩次,所以改進(jìn)為下面代碼。

var resizeTimer = null;
jQuery(window).resize(function () {
?? ?if (resizeTimer) clearTimeout(resizeTimer);
?? ?resizeTimer = setTimeout(function () {
?? ?// console.log("窗體發(fā)生改變了");
?? ?//todo
?? ?}, 100);
});

擴(kuò)展Jquery的resize方法

(原生的resize只針對(duì)window,因項(xiàng)目需要擴(kuò)展了此方法,目前只在DIV上使用過(guò),后續(xù)如果修改代碼會(huì)對(duì)此代碼進(jìn)行更新)

/**
?* 封裝非Window對(duì)象的resize方法
?* callback:回調(diào)函數(shù)(長(zhǎng)寬發(fā)生變化時(shí)觸發(fā))
?*/
$.fn.divResize=function(callback, setting){
? ?var cycleTime = 250; // 定義監(jiān)控大小變化的時(shí)間
? ?if(setting&&setting.cycleTime){
? ? ? cycleTime = setting.cycleTime;
? ?}
? ?if(callback==undefined||callback==null){
? ? ? return;
? ?}
? ?if(!(typeof callback == "function")){
? ? ? return;
? ?}
? ?$(this).each(function(){
? ? ? var resizeDom = this;
? ? ? resizeDom.data = {};
? ? ? resizeDom.data.width = $(resizeDom).css("width"); // 存放當(dāng)前寬度
? ? ? resizeDom.data.height = $(resizeDom).css("height"); // 存放當(dāng)前高度
? ? ? resizeDom.callback = callback;
? ? ? // 定義監(jiān)控函數(shù)
? ? ? var resizeMonitor = function(){
? ? ? ? ?// 判斷高度和寬度是否發(fā)生變化
? ? ? ? ?if($(resizeDom).css("width")!=resizeDom.data.width||$(resizeDom).css("height")!=resizeDom.data.height){
? ? ? ? ? ? resizeDom.data.width = $(resizeDom).css("width");
? ? ? ? ? ? resizeDom.data.height = $(resizeDom).css("height");
? ? ? ? ? ? resizeDom.callback();
? ? ? ? ?}
? ? ? ? ?var callFunc = arguments.callee; // 獲取本身函數(shù)
? ? ? ? ?setTimeout(function(){callFunc();}, cycleTime);
? ? ? };
? ? ? resizeMonitor();
? ?});
};
/**
?* 擴(kuò)展resize方法(可支持window和非window對(duì)象)
?* callback:回調(diào)函數(shù)(長(zhǎng)寬發(fā)生變化時(shí)觸發(fā))
?*/
? ?$.fn.resizeOld = $.fn.resize;
$.fn.resize=function(callback, setting){
? ?$(this).each(function(){
? ? ? ? ? ?var resizeDom = this;
? ? ? ?// 確定綁定的對(duì)象是否是window
? ? ? ? ? ?if (this == window) {
? ? ? ? ? ? ? ?$(window).resizeOld(function () {
? ? ? ? ? ? ? ? ? ?callback();
? ? ? ? ? ? ? ?});
? ? ? ? ? ?} else {
? ? ? ? ? ? ? ?resizeDom.callback = callback;
? ? ? ? ? ? ? ?$(this).divResize(callback, setting);
? ? ? ? ? ?}
? ?});
};

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論