我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Vue中自定义图片懒加载指令

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Vue中自定义图片懒加载指令

本篇文章为大家展示了Vue中自定义图片懒加载指令,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

先看如何使用这个指令:  

<img v-lazyload="imageclass="lazy" data-src" >

imageclass="lazy" data-src是要加载的图片的实际路径。

为了实现这个指令,我们首先单独建立一个文件,名字为lazyload.js.并填写基本的代码,如下:  

//Vue 图片懒加载,导出模块
export default (Vue , options = {})=>{
  //初始化的选项,default是未加载图片时显示的默认图片
  var init = {
     default: '/file/upload/202210/19/yzw3a4lpstj.png'
  }
  //addListener为Vue指令的具体实现功能函数,我们这里为所有使用v-lazyload的指令的元素添加监听
  //ele 是dom元素,binding是绑定的具体值,
  //例如:<img v-lazyload="imageclass="lazy" data-src" > ele是img binding是imageclass="lazy" data-src
  const addListenner = (ele,binding) =>{
    
  }
  //Vue自定义指令,lazyload为指令的名称
  Vue.directive('lazyload',{
    inserted:addListener,
    updated:addListener
  })
}

inserted 和 updated为Vue指令的执行不同阶段提供的钩子函数,查看Vue的官网可以看到一共有5个阶段, 

指令定义函数提供了几个钩子函数(可选):

bind: 只调用一次,指令第一次绑定到元素时调用,用这个钩子函数可以定义一个在绑定时执行一次的初始化动作。

inserted: 被绑定元素插入父节点时调用(父节点存在即可调用,不必存在于 document 中)。

update: 被绑定元素所在的模板更新时调用,而不论绑定值是否变化。通过比较更新前后的绑定值,可以忽略不必要的模板更新(详细的钩子函数参数见下)。

componentUpdated: 被绑定元素所在模板完成一次更新周期时调用。

unbind: 只调用一次, 指令与元素解绑时调用。

这里我们只用inserted和updated就够了。

  接下来我们具体实现addListener的实现。我们的具体思路如下:

  1、先看看这个图片是否需要懒加载。有两种情况,一是图片还没到达可视区域,二是图片已经加载过了。

  2、然后监听窗口的scroll事件,判断哪些图片可以进行懒加载了。

  这里我们需要一个需要进行监听需要懒加载的图片列表和一个需要记录已经加载过得图片列表。另外为了方便数组的操作,我们加一个数组的remove方法。

继续我们的代码。

//Vue 图片懒加载
export default (Vue , options = {})=>{
  
  //数组item remove方法
  if(!Array.prototype.remove){
    Array.prototype.remove = function(item){
      if(!this.length) return
      var index = this.indexOf(item);
      if( index > -1){
        this.splice(index,1);
        return this
      }
    }
  }
  var init = {   
    default: '/file/upload/202210/19/yzw3a4lpstj.png' 
  }  
  //需要进行监听的图片列表,还没有加载过得 
  var listenList = [];
  //已经加载过得图片缓存列表
  var imageCatcheList = [];
  //是否已经加载过了
  const isAlredyLoad = (imageclass="lazy" data-src) => {
    
  }
  //检测图片是否可以加载,如果可以则进行加载
  const isCanShow = (item) =>{
    
  };
  //添加监听事件scroll
  const onListenScroll = () =>{
    
  }
  //Vue 指令最终的方法
  const addListener = (ele,binding) =>{
    //绑定的图片地址
    var imageclass="lazy" data-src = binding.value;
    //如果已经加载过,则无需重新加载,直接将class="lazy" data-src赋值
    if(isAlredyLoad(imageclass="lazy" data-src)){
      ele.class="lazy" data-src = imageclass="lazy" data-src;
      return false;
    }
    var item = {
      ele:ele,
      class="lazy" data-src:imageclass="lazy" data-src
    }
    //图片显示默认的图片
    ele.class="lazy" data-src = init.default;
    //再看看是否可以显示此图片
    if(isCanShow(item)){
      return
    }
    //否则将图片地址和元素均放入监听的lisenList里
    listenList.push(item);
    
    //然后开始监听页面scroll事件
    onListenScroll();
  }

  Vue.directive('lazyload',{
    inserted:addListener,
    updated:addListener
  })
}

接下来就几个空方法的实现了。

isAlredyLoad ,判断是否已经加载过了这个图片

const isAlredyLoad = (imageclass="lazy" data-src) => {
    if(imageCatcheList.indexOf(imageclass="lazy" data-src) > -1){
      return true;
    }else{
      return false;
    }
  }

isCanShow 图片是否进入可视区域,如果已经进入则进行加载

//检测图片是否可以加载,如果可以则进行加载
  const isCanShow = (item) =>{
    var ele = item.ele;
    var class="lazy" data-src = item.class="lazy" data-src;
    //图片距离页面顶部的距离
    var top = ele.getBoundingClientRect().top;
    //页面可视区域的高度
    var windowHeight = window.innerHight;
    //top + 10 已经进入了可视区域10像素
    if(top + 10 < window.innerHeight){
      var image = new Image();
      image.class="lazy" data-src = class="lazy" data-src;
      image.onload = function(){
        ele.class="lazy" data-src = class="lazy" data-src;
        imageCatcheList.push(class="lazy" data-src);
        listenList.remove(item);
      }
      return true;
    }else{
      return false;
    }
  };

onListenScroll监听滚动事件,并且检测是否进入可视区域。

const onListenScroll = () =>{
    window.addEventListener('scroll',function(){
      var length = listenList.length;
      for(let i = 0;i<length;i++ ){
        isCanShow(listenList[i]);
      }
    })
  }

最终我们的代码如下:

//Vue 图片懒加载
export default (Vue , options = {})=>{
  if(!Array.prototype.remove){
    Array.prototype.remove = function(item){
      if(!this.length) return
      var index = this.indexOf(item);
      if( index > -1){
        this.splice(index,1);
        return this
      }
    }
  }
  var init = {
    lazyLoad: false,
    default: '/file/upload/202210/19/yzw3a4lpstj.png'
  }

  var listenList = [];
  var imageCatcheList = [];

  const isAlredyLoad = (imageclass="lazy" data-src) => {
    if(imageCatcheList.indexOf(imageclass="lazy" data-src) > -1){
      return true;
    }else{
      return false;
    }
  }
  //检测图片是否可以加载,如果可以则进行加载
  const isCanShow = (item) =>{
    var ele = item.ele;
    var class="lazy" data-src = item.class="lazy" data-src;
    //图片距离页面顶部的距离
    var top = ele.getBoundingClientRect().top;
    //页面可视区域的高度
    var windowHeight = window.innerHight;
    //top + 10 已经进入了可视区域10像素
    if(top + 10 < window.innerHeight){
      var image = new Image();
      image.class="lazy" data-src = class="lazy" data-src;
      image.onload = function(){
        ele.class="lazy" data-src = class="lazy" data-src;
        imageCatcheList.push(class="lazy" data-src);
        listenList.remove(item);
      }
      return true;
    }else{
      return false;
    }
  };

  const onListenScroll = () =>{
    window.addEventListener('scroll',function(){
      var length = listenList.length;
      for(let i = 0;i<length;i++ ){
        isCanShow(listenList[i]);
      }
    })
  }
  //Vue 指令最终的方法
  const addListener = (ele,binding) =>{
    //绑定的图片地址
    var imageclass="lazy" data-src = binding.value;
    //如果已经加载过,则无需重新加载,直接将class="lazy" data-src赋值
    if(isAlredyLoad(imageclass="lazy" data-src)){
      ele.class="lazy" data-src = imageclass="lazy" data-src;
      return false;
    }
    var item = {
      ele:ele,
      class="lazy" data-src:imageclass="lazy" data-src
    }
    //图片显示默认的图片
    ele.class="lazy" data-src = init.default;
    //再看看是否可以显示此图片
    if(isCanShow(item)){
      return
    }
    //否则将图片地址和元素均放入监听的lisenList里
    listenList.push(item);
    
    //然后开始监听页面scroll事件
    onListenScroll();
  }

  Vue.directive('lazyload',{
    inserted:addListener,
    updated:addListener
  })
}

使用时需要在主文件中引入这个文件,并且vue.use();

import LazyLoad from 'lazyLoad.js'
Vue.use(LazyLoad);

并且在需要懒加载的图片上均按照如下使用v-lazyload指令即可

<img v-lazyload="imageclass="lazy" data-src" >

上述内容就是Vue中自定义图片懒加载指令,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Vue中自定义图片懒加载指令

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

vue如何自定义加载指令

本文小编为大家详细介绍“vue如何自定义加载指令”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue如何自定义加载指令”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。前言用过element-ui的都应该知道,里面
2023-07-02

vue自定义加载指令v-loading占位图指令v-showimg

这篇文章主要为大家介绍了vue自定义加载指令和v-loading占位图指令v-showimg的示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-11-13

详解Vue自定义指令如何实现处理图片加载失败的碎图

这篇文章主要介绍了详解Vue自定义指令如何实现处理图片加载失败的碎图,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
2023-02-15

Android自定义ProgressDialog加载图片

为了提高用户体验,我们肯定希望该Dialog能更加炫酷,让用户看着更舒服。那如何做呢,当然是我们自己定义一个ProgressDialog了。一、使用系统加载框mDialog = new ProgressDialog(this); mDial
2022-06-06

Vue中lazyload图片懒加载得示例分析

这篇文章主要介绍Vue中lazyload图片懒加载得示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1.安装cnpm i vue-lazyload -S或npm i vue-lazyload -S2.实例导入配
2023-06-22

Vue中如何自定义指令

这篇文章主要介绍Vue中如何自定义指令,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Vue中除了内置指令,也允许注册自定义的指令。自定义指令提供一种将数据的变化映射为DOM的行为例如:当我们想用一个函数表示焦点Vue
2023-06-04

vue中有哪些自定义指令

这篇文章主要介绍“vue中有哪些自定义指令”,在日常操作中,相信很多人在vue中有哪些自定义指令问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue中有哪些自定义指令”的疑惑有所帮助!接下来,请跟着小编一起来
2023-06-22

vue中自定义指令怎么用

小编给大家分享一下vue中自定义指令怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!1、v-drag需求:鼠标拖动元素思路:元素偏移量 = 鼠标滑动后的坐标 - 鼠标初始点击元素时的坐标 + 初始点击时元素距离可视区域
2023-06-22

Vue中如何实现自定义指令?

Vue.js提供自定义指令功能,用于扩展其功能。创建自定义指令涉及定义指令对象并注册它。指令生命周期钩子函数在不同阶段调用。示例:v-highlight指令可高亮文本。自定义指令在创建可重用组件、扩展Vue功能、优化性能等场景中很有用。最佳实践包括保持简单、考虑性能、遵循命名约定和提供文档。
Vue中如何实现自定义指令?
2024-04-02

Android中自定义加载样式图片的具体实现

先让大家看看效果图吧,相信很多Android初学者都想知道这中效果是怎么实现的,来上图: 想实现上面这张图中的自定义加载样式,其实很简单,首先我们需要的布局组件有ProcessBar和TextView,下面是布局文件的代码(只是加载的页面的
2022-06-06

深入了解Vue中的自定义指令

对于Vue的自定义指令相信很多同学已经有所了解,自定义指令的具体写法这里就不细讲了,官方文档很详细。 但是不知道各位同学有没有这种感觉,就是这个技术感觉很方便,也不难,我也感觉学会了,就是不知道如何去应用。这篇文档就是为了解决一些同学的这些问题才写出来的。
2022-11-22

Vue中的自定义指令怎么实现

今天小编给大家分享一下Vue中的自定义指令怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。试炼:实现v-mymodel
2023-07-04

浅析vue中的自定义指令使用

最近做的项目,用了很多 Vue 的自定义指令,在同事等小伙伴之间调研发现,很多人几乎都不用 Vue 提供的这个能力。所以就把自己的一些使用方式整理一下分享给小伙伴,让大家也不要忽略自定义指令这个能力
2023-05-14

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录