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

vue里面如何使用圖片的懶加載

 更新時(shí)間:2022年10月09日 09:37:13   作者:The_more_more  
這篇文章主要介紹了vue里面如何使用圖片的懶加載,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

前言

什么是懶加載

  • 通俗地講就是需要用到圖片的時(shí)候再去加載
  • 懶加載的好處在于減少服務(wù)器的壓力,在網(wǎng)絡(luò)比較慢的情況下,可以提前給這張圖片添加一個(gè)占位圖片,提高用戶的體驗(yàn)。

一、安裝相關(guān)的包

安裝懶加載所需的包

npm install vue-lazyload --save

二、使用步驟

1.引入

在項(xiàng)目的入口文件引入包,然后注冊(cè)

代碼如下(示例):

import Vue from 'vue'
import App from './App.vue'
Vue.config.productionTip = false
// 引入插件
import VueLazyload from 'vue-lazyload'
// 注冊(cè)插件
Vue.use(VueLazyload,{
  loading:'https://www.keaidian.com/uploads/allimg/190424/24110307_8.jpg' // 懶加載默認(rèn)圖片
})
new Vue({
  render: h => h(App),
}).$mount('#app')

一些參數(shù)的解析:

  • preLoad:表示lazyload的元素,距離頁(yè)面底部距離的百分比.計(jì)算值為(preload - 1),默認(rèn)值為1.3
  • error:表式加載失敗展示的圖片,需要傳入一個(gè)字符串作為解析
  • loading:表式加載成功展示的圖片,需要傳入一個(gè)字符串作為解析
  • attempt:圖片加載失敗后的重試次數(shù),需要傳入一個(gè)Number

修改懶加載的樣式可以使用以下代碼:

img[lazy="loading"]{
  display:block;
  width:150px !important;
  height:150px !important;
  margin:0 auto;
  }

這樣的樣式可以根據(jù)自己的需求而定,并不是必須配置

詳細(xì)內(nèi)容見(jiàn):https://www.npmjs.com/package/vue-lazyload

2.使用

在創(chuàng)建好的項(xiàng)目里面簡(jiǎn)單使用

使用 ( :src—>v-lazy )

代碼如下(示例):

<template>
  <div id="app">
    <img alt="Vue logo" src="./assets/logo.png" />
    <br />
    <img v-lazy="a ? img[0] : img[1]" @click="changeImg" />
  </div>
</template>
<script>
export default {
  name: 'App',
  data() {
    return {
      a: true,
      img: [
        // 圖片一
        'https://tse1-mm.cn.bing.net/th/id/OIP-C.ETHKvrgFkIGb1teNrFHIYQHaLH?w=186&h=279&c=7&r=0&o=5&dpr=1.25&pid=1.7',
        // 圖片二
        'https://tse2-mm.cn.bing.net/th/id/OIP-C.zPTuPEWVwIUcWgJSi93yLwHaLG?w=186&h=279&c=7&r=0&o=5&dpr=1.25&pid=1.7'
      ]
    }
  },
  methods: {
    changeImg() {
      this.a = !this.a
    }
  }
}
</script>
<style>
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

如果是循環(huán)出來(lái)的圖片,我們需要指定一個(gè)key值,例如:

 <img v-lazy="img.src" :key="img.src" >

觀察是否實(shí)現(xiàn)懶加載

1.首先需要把項(xiàng)目運(yùn)行起來(lái)

在控制臺(tái)輸入npm run serve

2.定位到相關(guān)的目錄打開(kāi)開(kāi)發(fā)者調(diào)試(F12)

3.找到 “網(wǎng)絡(luò)的選項(xiàng)” ,把網(wǎng)絡(luò)改成慢速3G,再打開(kāi)禁用緩存

在這里插入圖片描述

4.刷新界面,觀察圖片的變化

三、關(guān)于包的相關(guān)構(gòu)成

1. 簡(jiǎn)單介紹

包的主要構(gòu)成是使用自定義插件和自定義指令來(lái)體現(xiàn)的

2. 簡(jiǎn)單操作

在src文件夾下創(chuàng)建plugins的文件夾,里面用于封裝插件,再在該文件夾下創(chuàng)建TheWorld.js的文件書

寫插件,代碼如下:

// 插件暴露的必須是一個(gè)對(duì)象
let TheWorld = {}
TheWorld.install = function (Vue, options) {
  // console.log('我是插件,我調(diào)用了') // 當(dāng)在main.js文件引入注冊(cè)的時(shí)候就會(huì)調(diào)用
  // console.log(Vue)  // 可以收到參數(shù)Vue
  // console.log(options)  // 可以收到參數(shù)配置對(duì)象
  // 有了Vue,我們可以調(diào)用Vue身上的系列api,比如Vue.component;Vue.filter等等
  
  Vue.directive(options.name, (element, params) => {
    // console.log('我執(zhí)行了') // 當(dāng)頁(yè)面使用的時(shí)候就會(huì)執(zhí)行
    // 會(huì)收到參數(shù)element:綁定的元素;params:該對(duì)象的一些對(duì)象信息
    
    element.innerHTML = params.value.toUpperCase()
    
    // 在params里面有個(gè)參數(shù)modifiers里面保存著修飾符,當(dāng)你使用自定義指令的時(shí)候加上的修飾符將存入modifiers里面
  })
}
export default TheWorld

Vue.js的插件應(yīng)該暴露一個(gè)install方法。這個(gè)方法的第一個(gè)參數(shù)是Vue構(gòu)造器,第二個(gè)參數(shù)是一個(gè)可選的選項(xiàng)對(duì)象

在頁(yè)面我們就可以使用了:

<template>
  <div id="app">
    <img alt="Vue logo" src="./assets/logo.png" />
    <br />
    <p v-world="text"></p>
  </div>
</template>
<script>
export default {
  name: 'App',
  data() {
    return {
      text: 'theworld'
    }
  }
}
</script>
<style>
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

此時(shí)頁(yè)面呈現(xiàn)的就是THEWORLD了

了解更多詳情參考Vue的文檔:https://cn.vuejs.org/v2/guide/custom-directive.html

總結(jié)

以上就是關(guān)于在Vue里面圖片懶加載的一種處理方式,處理圖片懶加載的方法有很多種,但核心固然不變,實(shí)現(xiàn)圖片懶加載的簡(jiǎn)單原理,在于監(jiān)聽(tīng)圖片的變化,將變化的圖片替代所展示的默認(rèn)圖片。

希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vite打包優(yōu)化分片打包依賴包詳解

    vite打包優(yōu)化分片打包依賴包詳解

    這篇文章主要介紹了vite打包優(yōu)化分片打包依賴包,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • vue?filter的幾種用法示例小結(jié)

    vue?filter的幾種用法示例小結(jié)

    Vue.filter函數(shù)用于注冊(cè)一個(gè)全局的過(guò)濾器,該過(guò)濾器可以在模板和組件中使用,這篇文章主要介紹了vue?filter的幾種用法示例小結(jié),需要的朋友可以參考下
    2024-08-08
  • Vue使用emit傳參,父組件接收不到數(shù)據(jù)的問(wèn)題及解決

    Vue使用emit傳參,父組件接收不到數(shù)據(jù)的問(wèn)題及解決

    這篇文章主要介紹了Vue使用emit傳參,父組件接收不到數(shù)據(jù)的問(wèn)題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-09-09
  • Vue的props父?jìng)髯拥氖纠a

    Vue的props父?jìng)髯拥氖纠a

    這篇文章主要介紹了Vue的props父?jìng)髯拥氖纠a,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • Vue中進(jìn)行數(shù)據(jù)緩存的使用示例

    Vue中進(jìn)行數(shù)據(jù)緩存的使用示例

    數(shù)據(jù)緩存可以提高應(yīng)用程序的性能,減少網(wǎng)絡(luò)請(qǐng)求,提高用戶體驗(yàn),在本文中,我們介紹了Vue中如何進(jìn)行數(shù)據(jù)緩存,并提供了一些示例代碼,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-09-09
  • vue百度地圖 + 定位的詳解

    vue百度地圖 + 定位的詳解

    這篇文章主要介紹了vue百度地圖 + 定位的詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • elementUI Tree 樹(shù)形控件的官方使用文檔

    elementUI Tree 樹(shù)形控件的官方使用文檔

    這篇文章主要介紹了elementUI Tree 樹(shù)形控件的官方使用文檔,用清晰的層級(jí)結(jié)構(gòu)展示信息,可展開(kāi)或折疊。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-04-04
  • Vue中.vue文件比main.js先執(zhí)行的問(wèn)題及解決

    Vue中.vue文件比main.js先執(zhí)行的問(wèn)題及解決

    這篇文章主要介紹了Vue中.vue文件比main.js先執(zhí)行的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • Vue和原生JS中如何使用自定義字體

    Vue和原生JS中如何使用自定義字體

    這篇文章主要為大家詳細(xì)介紹了Vue和原生JS中如何使用自定義字體,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的小伙伴可以了解下
    2024-01-01
  • vue源碼學(xué)習(xí)之Object.defineProperty對(duì)象屬性監(jiān)聽(tīng)

    vue源碼學(xué)習(xí)之Object.defineProperty對(duì)象屬性監(jiān)聽(tīng)

    這篇文章主要介紹了vue源碼學(xué)習(xí)之Object.defineProperty對(duì)象屬性監(jiān)聽(tīng),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-05-05

最新評(píng)論