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

vue-lazyload使用總結(jié)(推薦)

 更新時(shí)間:2018年11月01日 14:10:04   作者:秋天愛美麗  
vue項(xiàng)目用到vue-lazyload做圖片懶加載,這篇文章主要介紹了vue-lazyload使用總結(jié),解決這個(gè)插件的坑,非常具有實(shí)用價(jià)值,需要的朋友可以參考下

當(dāng)你用vue開發(fā)的時(shí)候,不可避免的就會遇到圖片懶加載的問題,之前jquery時(shí)代有jquery.lazyload.js,但是那個(gè)肯定不能用在vue的項(xiàng)目里。查閱資料后發(fā)現(xiàn)Vue-Lazyload這個(gè)插件用的頻率還是比較高,最近剛好也在研究vue的懶加載,順便也仔細(xì)研究了以下這個(gè)插件,這個(gè)插件確實(shí)能夠?qū)崿F(xiàn)懶加載,但是坑也有不少,今天就一起來看看Vue-Lazyload。 Vue-Lazyload的github地址

主要功能&實(shí)現(xiàn)思路

這篇文章不是去講解這個(gè)插件是如何配置的,這個(gè)在它的github上都有介紹,因此你要先大致了解它是如何配置的。這里主要從源碼角度去分析該如何正確使用這款插件。

v-lazy

這個(gè)是Vue-Lazyload最常用的一個(gè)東西,用法也非常的簡單:

<ul>
   <li v-for="img in list">
     <img v-lazy="img.src" >
   </li>
</ul>

我們現(xiàn)在來看看它的內(nèi)部是如何實(shí)現(xiàn)的,首先我們進(jìn)入它github上的源碼可以發(fā)現(xiàn)它的定義:

Vue.directive('lazy', {
  bind: lazy.add.bind(lazy),
  update: lazy.update.bind(lazy),
  componentUpdated: lazy.lazyLoadHandler.bind(lazy),
  unbind: lazy.remove.bind(lazy)
})
Vue.directive('lazy-container', {
  bind: lazyContainer.bind.bind(lazyContainer),
  update: lazyContainer.update.bind(lazyContainer),
  unbind: lazyContainer.unbind.bind(lazyContainer)
})

我們可以發(fā)現(xiàn)它是利用vue的自定義指令實(shí)現(xiàn)的,vue的自定義指令可以自定義v-***之類的指令,例如你定義了Vue.directive('demo',..)那么你就可以使用v-demo這樣的指令,當(dāng)你使用了之后就會有對應(yīng)事件供你回調(diào),例如bind,insert,unbind等,具體可以看看下面的demo:

=> vue自定義指令(二維碼)

進(jìn)入demo后我們可以看到一進(jìn)去就出發(fā)了bind和insert事件,然后你在輸入框輸入內(nèi)容就會觸發(fā)update和updateComponent事件,當(dāng)你點(diǎn)擊隱藏就會觸發(fā)unbind事件,當(dāng)你點(diǎn)擊顯示則又會觸發(fā)bind和insert事件。(具體含義可以去查閱官方文檔)

vue的自定義指令還可以帶參數(shù),例如vue-lazy:background-image.container='src'這樣的結(jié)構(gòu),我們可以通過事件里面的binding參數(shù)獲取到,例如上面的background-image可以通過binding.arg獲取,.container可以通過binding.modifiers獲取。

好了,講了這么多,v-lazy的實(shí)現(xiàn)思路應(yīng)該比較清楚了,就是內(nèi)部實(shí)現(xiàn)了一個(gè)lazy的類,通過vue自定義指令將對象和參數(shù)傳進(jìn)去,然后通過檢測事件(scroll等)檢測位置,如果一旦這個(gè)對象出現(xiàn)在屏幕里就加載圖片。下面看看已經(jīng)實(shí)現(xiàn)好的demo:(包含img的v-lazy和div的v-lazy:background-image兩種情況)

=> v-lazy demo(二維碼)

注意:這里的v-lazy='src'中的src一定要使用data里面的變量,不能寫真實(shí)的圖片路徑,這樣會報(bào)錯(cuò)導(dǎo)致沒有效果,因?yàn)関ue的自定義指令必須對應(yīng)data中的變量或者是數(shù)字,你寫一個(gè)圖片路徑識別不了,我之前就是被坑了。(這里的圖片fadeIn效果是在load事件之后添加了一個(gè)fadeIn的class)。

v-lazy-container

這個(gè)總體上和v-lazy差不多,也是通過自定義指令去定義的,不過v-lazy-container掃描的是內(nèi)部的子元素,v-lazy-container一般使用如下:

<div v-lazy-container="{ selector: 'img' }">
   <img data-src="http://domain.com/img1.jpg">
  <img data-src="http://domain.com/img2.jpg">
  <img data-src="http://domain.com/img3.jpg">
</div>

v-lazy-container和v-lazy不同的是,v-lazy-container是通過設(shè)置指定的子元素的data-src,data-loading,data-error去設(shè)置圖片的路徑的,我們看內(nèi)部實(shí)現(xiàn)就可以看到:

const imgs = this.getImgs()
imgs.forEach(el => {
   this.lazy.add(el, assign({}, this.binding, {
     value: {
       src: 'dataset' in el ? el.dataset.src : el.getAttribute('data-src'),
       error: 'dataset' in el ? el.dataset.error : el.getAttribute('data-error'),
       loading: 'dataset' in el ? el.dataset.loading : el.getAttribute('data-loading')
     }
   }), this.vnode)
 })

下面是寫好的v-lazy-container demo:

=> v-lazy-container demo(二維碼)

注:v-lazy-container內(nèi)部指定元素設(shè)置的data-src是圖片的真實(shí)路徑,不能是data變量,這個(gè)和v-lazy完全相反。

lazy-component

這個(gè)和上面的不太一樣,這個(gè)嚴(yán)格來說不單單能夠做圖片懶加載,還可以做組件的懶加載,一般結(jié)構(gòu)如下:

<lazy-component @show="handler">
   <img class="mini-cover" :src="img.src" width="100%" height="400">
</lazy-component>

實(shí)現(xiàn)方面,先用Vue.component('lazy-component',...)注冊了一個(gè)全局的組件,然后通過檢測位置,如果在視圖范圍之內(nèi)就吐出它內(nèi)部的內(nèi)容,這個(gè)設(shè)計(jì)還是比較巧妙:

render (h) {
   if (this.show === false) {
     return h(this.tag)
   }
   return h(this.tag, null, this.$slots.default)
 },

我們一般用component都是指定一個(gè)template,它這里是利用render來自己生成內(nèi)容,它這里通過一個(gè)變量show控制是否繪制內(nèi)部的內(nèi)容,開始的時(shí)候show為false,那么這里就繪制一個(gè)div(tag為div),等檢測(檢測div)出現(xiàn)屏幕了,show就為true,就會繪制它內(nèi)部的真實(shí)內(nèi)容了(this.$slots.default就是自定義控件下面的內(nèi)容)。

lazy-component作為一個(gè)組件,給外部提供了一個(gè)回調(diào)事件(show),表示已經(jīng)開始load了,所以我們可以在外層監(jiān)聽這個(gè)事件:

load () {
   this.show = true
   this.state.loaded = true
   this.$emit('show', this)
 }

我們來看一個(gè)做好的demo,這個(gè)demo還是以實(shí)現(xiàn)圖片懶加載為主。

=> lazy-component demo(二維碼)

注:lazy-component本身不能實(shí)現(xiàn)圖片懶加載,它只是實(shí)現(xiàn)組件懶加載,上面demo真正實(shí)現(xiàn)懶加載是因?yàn)橛昧藇-lazy。lazy-component有一個(gè)問題,就是它的上方必須要有東西,否則可能沒有效果,因?yàn)樗跈z測的時(shí)候有一個(gè)判斷:bottom>0,所以如果你在第一個(gè)元素使用lazy-component可能沒有效果。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 怎樣在vue項(xiàng)目下添加ESLint的方法

    怎樣在vue項(xiàng)目下添加ESLint的方法

    這篇文章主要介紹了怎樣在vue項(xiàng)目下添加ESLint的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-05-05
  • 在vue中使用vant TreeSelect分類選擇組件操作

    在vue中使用vant TreeSelect分類選擇組件操作

    這篇文章主要介紹了在vue中使用vant TreeSelect分類選擇組件操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • Vue實(shí)現(xiàn)下拉加載更多

    Vue實(shí)現(xiàn)下拉加載更多

    這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)下拉加載更多,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • Vue3.2中setup語法糖的使用教程分享

    Vue3.2中setup語法糖的使用教程分享

    這篇文章主要為大家詳細(xì)介紹了Vue3.2中setup語法糖的具體使用方法,文中的示例代碼講解詳細(xì),對我們深入了解Vue有一定的幫助,需要的可以參考一下
    2023-05-05
  • vue實(shí)現(xiàn)拖拽小圖標(biāo)

    vue實(shí)現(xiàn)拖拽小圖標(biāo)

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)拖拽小圖標(biāo),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 完美解決vue 中多個(gè)echarts圖表自適應(yīng)的問題

    完美解決vue 中多個(gè)echarts圖表自適應(yīng)的問題

    這篇文章主要介紹了完美解決vue 中多個(gè)echarts圖表自適應(yīng)的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • Laravel 如何在blade文件中使用Vue組件的示例代碼

    Laravel 如何在blade文件中使用Vue組件的示例代碼

    這篇文章主要介紹了Laravel 如何在blade文件中使用Vue組件,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-06-06
  • 使用VueRouter的addRoutes方法實(shí)現(xiàn)動態(tài)添加用戶的權(quán)限路由

    使用VueRouter的addRoutes方法實(shí)現(xiàn)動態(tài)添加用戶的權(quán)限路由

    這篇文章主要介紹了使用VueRouter的addRoutes方法實(shí)現(xiàn)動態(tài)添加用戶的權(quán)限路由,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-06-06
  • Vue計(jì)算屬性與監(jiān)視(偵聽)屬性的使用深度學(xué)習(xí)

    Vue計(jì)算屬性與監(jiān)視(偵聽)屬性的使用深度學(xué)習(xí)

    這篇文章主要介紹了Vue計(jì)算屬性與監(jiān)視(偵聽)屬性的使用,計(jì)算屬性指的是通過一系列運(yùn)算之后,最終得到一個(gè)值,watch監(jiān)視(偵聽)器允許開發(fā)者監(jiān)視數(shù)據(jù)的變化,從而針對數(shù)據(jù)的變化做特定的操作,本文就這兩種屬性給大家詳細(xì)講解,感興趣的朋友一起學(xué)習(xí)吧
    2022-11-11
  • vue遞歸實(shí)現(xiàn)自定義tree組件

    vue遞歸實(shí)現(xiàn)自定義tree組件

    這篇文章主要為大家詳細(xì)介紹了vue遞歸實(shí)現(xiàn)自定義tree組件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08

最新評論