一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

記一次失敗的jQuery優(yōu)化嘗試

  我經(jīng)常抱怨jQuery的DOM操作性能并不優(yōu)秀,并且經(jīng)常嘗試用一些方法去進行優(yōu)化,但是越是優(yōu)化,越是沮喪地發(fā)現(xiàn)jQuery其實已經(jīng)做得很好,從使用者的角度能夠進行的優(yōu)化實在有限(這并不意味著jQuery的性能是優(yōu)秀的, 反之只能說它是一個相對封閉的庫,無法從外部介入進行優(yōu)化)。這篇文章就記錄一次失敗的優(yōu)化經(jīng)歷。

  優(yōu)化思想

  這一次優(yōu)化的思想來自于數(shù)據(jù)庫。在數(shù)據(jù)庫優(yōu)化的時候,我們常會說將大量的操作放在一個事務(wù)中一起提交,能有效提高效率。雖然對數(shù)據(jù)庫不了解的我并不知道其原因,但是事務(wù)的思想?yún)s為我指明了方向(雖然是錯的)。

  因此我嘗試將事務(wù)這一概念引入到j(luò)Query中,通過打開和提交事務(wù),從外部對jQuery進行一些優(yōu)化,其最重要的在于減少each函數(shù)的循環(huán)次數(shù)。

  眾所周知,jQuery的DOM操作,以get all, set first為標(biāo)準(zhǔn),其中用于設(shè)置DOM屬性/樣式的操作,幾乎都是對選擇出來的元素的一次遍歷,jQuery.access函數(shù)就是其中最核心的部分,其中用于循環(huán)的代碼如下:

// Setting one attribute
if ( value !== undefined ) {
// Optionally, function values get executed if exec is true
exec = !pass exec jQuery.isFunction(value);

for ( var i = 0; i length; i++ ) {
fn(
elems[i],
key,
exec
? value.call(elems[i], i, fn(elems[i], key)) : value,
pass
);
}

return elems;

it知識庫記一次失敗的jQuery優(yōu)化嘗試,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 色婷婷免费视频 | 午夜精品视频在线 | 国产高清视频免费最新在线 | 五月婷婷小说 | 无遮挡毛片a级武则天 | 欧美日韩福利视频一区二区三区 | 国内偷拍第一页 | 国产激情在线观看 | 六月综合网 | 国产区一区二 | 久久伊人中文字幕 | 中文字幕一区二区区免 | 国产精品自在自线免费观看 | 色播亚洲精品网站 亚洲第一 | 亚洲精品人成无码中文毛片 | 国产激情网 | 亚洲免费精品视频 | 91久久精品青青草原伊人 | 小视频免费在线观看 | 色四虎| 国产视频第一页 | 国产一区二区不卡视频 | 国产精品久久久久影视不卡 | 日本加勒比在线观看 | 欧美激情在线看 | 欧美色网络 | 欧美zoosex| 福利视频一区二区三区 | 视频免费1区二区三区 | 婷婷97狠狠的狠狠的爱 | 深夜福利一区 | 视色4se影院在线播放 | 伊人色综合久久天天网 | 两性午夜刺激性视频 | 久久精品国产线看观看亚洲 | 99成人在线| 四虎永久在线精品视频播放 | 四虎影视永久免费 | 中文字幕91在线 | 最近中文字幕完先锋资源 | 在线精品国内视频秒播 |