js圖片懶加載

轉(zhuǎn)載地址

http://hjingren.cn/2017/06/09/js%E5%AE%9E%E7%8E%B0%E5%9B%BE%E7%89%87%E6%87%92%E5%8A%A0%E8%BD%BD/


懶加載的意義

懶加載的主要目的是作為服務器前端的優(yōu)化晒杈,減少請求數(shù)或延遲請求數(shù)调窍,對服務器緩壓葬馋。

預加載:提前加載好研铆,緩存到本地丽声,當需要的時候直接讀取緩存,對服務器增壓

懶加載實現(xiàn)方式

第一種是純粹的延遲加載,使用setTimeOut或setInterval進行加載延遲

第二種是條件加載,符合某些條件譬胎,或觸發(fā)了某些事件才開始異步下載

第三種是可視區(qū)加載,即僅加載用戶可以看到的區(qū)域命锄,這個主要由監(jiān)控滾動條來實現(xiàn)堰乔,一般會在距用戶看到某圖片前一定距離遍開始加載,這樣能保證用戶拉下時正好能看到圖片

Web 圖片的懶加載就是通過讀取img元素脐恩,然后獲得img元素的data-src(也可以約定為其他屬性名)屬性的值镐侯,并賦予img的src,從而實現(xiàn)動態(tài)加載圖片的機制

1驶冒、懶加載HTML約定

我們首先需要給準備實施懶加載的img元素添加指定的class 這里為m-lazyload ,同時將img src賦值給 data-src屬性苟翻。

具體示例為:

1

2、懶加載JavaScript實現(xiàn)

動態(tài)加載總共分為以下幾個步驟:

1骗污、添加頁面滾動監(jiān)聽事件

window.addEventListener('scroll', _delay,false);

function_delay(){

???? clearTimeout(delay);

???? delay = setTimeout(function(){

???????????? _loadImage();

?????? }, time);

}

2崇猫、當觸發(fā)監(jiān)聽事件時會執(zhí)行 _loadImage 函數(shù),該函數(shù)負責加載圖片

function_loadImage(){

?? for(vari = imgList.length; i--;) {

??????? varel = imgList[i];

??????? if(_isShow(el)) {

??????????? el.src = el.getAttribute('data-src');

??????????? el.className = el.className.replace(newRegExp("(\\s|^)"+ _selector.substring(1, _selector.length) +"(\\s|$)")," ");

???????????? imgList.splice(i,1);

???????? }

???? }

}

3身堡、判斷該圖片是否在當前窗口的可視區(qū)域內(nèi)

function_isShow(el){

??? varcoords = el.getBoundingClientRect();

???? return( (coords.top >=0&& coords.left >=0&& coords.top) <= (window.innerHeight? ||document.documentElement.clientHeight) +parseInt(offset));

}

到這一個簡單的圖片懶加載就寫成了

當網(wǎng)頁滾動的事件被觸發(fā) -> 執(zhí)行加載圖片操作 -> 判斷圖片是否在可視區(qū)域內(nèi) -> 在邓尤,則動態(tài)將data-src的值賦予該圖片拍鲤。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末贴谎,一起剝皮案震驚了整個濱河市汞扎,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌擅这,老刑警劉巖澈魄,帶你破解...
    沈念sama閱讀 219,589評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異仲翎,居然都是意外死亡痹扇,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,615評論 3 396
  • 文/潘曉璐 我一進店門溯香,熙熙樓的掌柜王于貴愁眉苦臉地迎上來鲫构,“玉大人,你說我怎么就攤上這事玫坛〗岜浚” “怎么了?”我有些...
    開封第一講書人閱讀 165,933評論 0 356
  • 文/不壞的土叔 我叫張陵湿镀,是天一觀的道長炕吸。 經(jīng)常有香客問我,道長勉痴,這世上最難降的妖魔是什么赫模? 我笑而不...
    開封第一講書人閱讀 58,976評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮蒸矛,結(jié)果婚禮上瀑罗,老公的妹妹穿的比我還像新娘。我一直安慰自己雏掠,他們只是感情好廓脆,可當我...
    茶點故事閱讀 67,999評論 6 393
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著磁玉,像睡著了一般停忿。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蚊伞,一...
    開封第一講書人閱讀 51,775評論 1 307
  • 那天席赂,我揣著相機與錄音,去河邊找鬼时迫。 笑死虐呻,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的硅则。 我是一名探鬼主播筐赔,決...
    沈念sama閱讀 40,474評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了喊熟?” 一聲冷哼從身側(cè)響起柏肪,我...
    開封第一講書人閱讀 39,359評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎芥牌,沒想到半個月后烦味,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,854評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡壁拉,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,007評論 3 338
  • 正文 我和宋清朗相戀三年谬俄,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片弃理。...
    茶點故事閱讀 40,146評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡溃论,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出痘昌,到底是詐尸還是另有隱情蔬芥,我是刑警寧澤,帶...
    沈念sama閱讀 35,826評論 5 346
  • 正文 年R本政府宣布控汉,位于F島的核電站笔诵,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏姑子。R本人自食惡果不足惜乎婿,卻給世界環(huán)境...
    茶點故事閱讀 41,484評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望街佑。 院中可真熱鬧谢翎,春花似錦、人聲如沸沐旨。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,029評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽磁携。三九已至褒侧,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間谊迄,已是汗流浹背闷供。 一陣腳步聲響...
    開封第一講書人閱讀 33,153評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留统诺,地道東北人歪脏。 一個月前我還...
    沈念sama閱讀 48,420評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像粮呢,于是被迫代替她去往敵國和親婿失。 傳聞我的和親對象是個殘疾皇子钞艇,可洞房花燭夜當晚...
    茶點故事閱讀 45,107評論 2 356

推薦閱讀更多精彩內(nèi)容

  • tips:接下去會在github寫博客,簡書不再更新和修改文章豪硅,歡迎大家逛逛我的新博客點擊查看 哩照,我會盡量用更容易...
    aermin閱讀 2,123評論 0 34
  • 1.引入echo.js。此處選擇引入BootCDN靜態(tài)資源庫的路徑舟误。 2.在使用img標簽時src設置為默認緩沖加...
    放開那小超閱讀 753評論 0 0
  • 給大家分享一下JS的圖片懶加載
    王哥來了閱讀 315評論 0 2
  • 編碼時要注意所有的img標簽里的src屬性都要寫成_src葡秒。函數(shù)getPos是為了得到obj的定位父級的left和...
    vikang閱讀 387評論 5 10
  • 從畢業(yè)到現(xiàn)在已經(jīng)工作兩年半了姻乓,不出所料地在近兩個月出現(xiàn)了倦怠狀態(tài)嵌溢,雖然很不愿意承認,可自己最擔心的這種狀態(tài)還是出現(xiàn)...
    醉臥十里風閱讀 62評論 0 0