js实现图片加载淡入淡出效果


Posted in Javascript onApril 07, 2017

本文实例为大家分享了js图片加载淡入淡出效果展示的具体代码,供大家参考,具体内容如下

HTML代码

首先是图片标记的写法:

<img data-src="/path/to/image.jpg" alt="">

需要将图片的地址放到 data-src 属性里,而src值填写默认的一张图片。

CSS代码

所有具有data-src属性的图片,我们将其初始显示状态为不可见,通过透明度来调节:

img {
 opacity: 1;
 transition: opacity 0.3s;
}

img[data-src] {
 opacity: 0;
}

这样写的作用是什么?等当图片加载时,你就能看的效果了。

JavaScript代码

我们最终会将 data-src 属性去掉,换成src属性,但这是图片加载成功后的动作:

[].forEach.call(document.querySelectorAll('img[data-src]'), function(img) {
 img.setAttribute('src', img.getAttribute('data-src'));
 img.onload = function() {
  img.removeAttribute('data-src');
 };
});

相比起其它各种的图片延迟加载技术,这种方法非常的简单,它几乎不要求其它任何条件,可以用在任何地方,使用起来非常灵活。

当然,简单有简单的好坏,也会因为简单而不足。它不具有图片图片滚动到可视窗口内再加载的功能。最终使用哪种技术,还是要看场景而定。

下面是lazyload.js

var lazyLoad = {
 init: function() {
  var that = this;
  that.onerrorImgUrl = "data-error"; //图片加载失败用什么图片替换
  that.srcStore = "data-src"; //图片真实地址存放的自定义属性
  that.class = "lazy-img"; //惰性加载的图片需要添加的class
  that.sensitivity = 50; //该值越小,惰性越强(加载越少)
  minScroll = 5,
  slowScrollTime = 200;

  document.addEventListener("scroll", function() {
   that.changeimg();
  });

  setTimeout(function() {
   that.trigger();
  }, 100);

 },
 scanImage: function() {
  var that = this;
  var imgList = [];
  var allimg = [].slice.call(document.querySelectorAll('img.' + that.class + ''));
  allimg.forEach(function(ele) {
   if (!that.isLoadedImageCompleted(ele)) {
    imgList.push(ele);
   }
  });

  that.imglistArr = imgList;
 },
 isLoadedImageCompleted: function(ele) {
  return (ele.getAttribute('data-loaded') == '1')
 },
 trigger: function() {
  var that = this;
  eventType = that.isPhone && "touchend" || "scroll";
  that.fireEvent(document, eventType);
  //$(window).trigger(eventType);
 },
 fireEvent: function(element, event) {
  // 其他标准浏览器使用dispatchEvent方法
  var evt = document.createEvent('HTMLEvents');
  // initEvent接受3个参数:
  // 事件类型,是否冒泡,是否阻止浏览器的默认行为
  evt.initEvent(event, true, true);
  return !element.dispatchEvent(evt);
 },
 changeimg: function() {
  function loadYesOrno(img) {
   var windowPageYOffset = window.pageYOffset,
    windowPageYOffsetAddHeight = windowPageYOffset + window.innerHeight,
    imgOffsetTop = img.getBoundingClientRect().top + window.pageYOffset;
   return imgOffsetTop >= windowPageYOffset && imgOffsetTop - that.sensitivity <= windowPageYOffsetAddHeight;
  }

  function loadImg(img, index) {

   var imgUrl = img.getAttribute(that.srcStore);

   img.setAttribute("src", imgUrl);

   img.onload || (img.onload = function() {
     img.classList.remove(that.class);
     img.setAttribute('data-loaded', 1)
     img.removeAttribute('data-src');
     //$(this).removeClass(that.class).getAttribute('data-loaded',1),
     that.imglistArr[index] = null;
     img.onerror = img.onload = null;
    },
    img.onerror = function() {
     img.src = img.getAttribute(that.onerrorImgUrl);
     img.classList.remove(that.class);
     img.classList.add("lazy-err");
     img.setAttribute('data-loaded', 0);
     //$(this).removeClass(that.class).getAttribute('data-loaded',0),
     that.imglistArr[index] = null,
      img.onerror = img.onload = null
    });

   var newImgStack = [];
   that.imglistArr.forEach(function(ele) {

    //img标签可见并且加载未完成
    if (!that.isLoadedImageCompleted(ele)) {
     newImgStack.push(ele);
    }
   });
   that.imglistArr = newImgStack;
  }

  var that = this;
  that.scanImage();
  that.imglistArr.forEach(function(val, index) {

   if (!val) return;
   var img = val;
   if (!loadYesOrno(img) || that.isLoadedImageCompleted(img)) return;

   if (!img.getAttribute(that.srcStore)) return;

   loadImg(img, index);
  })

 }
};

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
asp.net下使用jquery 的ajax+WebService+json 实现无刷新取后台值的实现代码
Sep 19 Javascript
基于Jquery的仿照flash放大图片效果代码
Mar 16 Javascript
js实现跨域的多种方法
Dec 25 Javascript
JavaScript事件代理和委托详解
Apr 08 Javascript
JavaScript实现图片懒加载(Lazyload)
Nov 28 Javascript
livereload工具实现前端可视化开发【推荐】
Dec 23 Javascript
node.js程序作为服务并在windows下开机自启动(用forever)
Mar 29 Javascript
浅谈struts1 &amp; jquery form 文件异步上传
May 25 jQuery
JavaScript代码执行的先后顺序问题
Oct 29 Javascript
解决vue打包项目后刷新404的问题
Mar 06 Javascript
详解Vue中组件传值的多重实现方式
Aug 16 Javascript
Vue3如何理解ref toRef和toRefs的区别
Feb 18 Vue.js
AngularJS中的拦截器实例详解
Apr 07 #Javascript
Vue.js如何优雅的进行form validation
Apr 07 #Javascript
详解Node.js实现301、302重定向服务
Apr 07 #Javascript
Express URL跳转(重定向)的实现方法
Apr 07 #Javascript
微信小程序 首页制作简单实例
Apr 07 #Javascript
微信小程序 商城开发(ecshop )简单实例
Apr 07 #Javascript
js控制文本框禁止输入特殊字符详解
Apr 07 #Javascript
You might like
smarty实现多级分类的方法
2014/12/05 PHP
简单解决微信文章图片防盗链问题
2016/12/17 PHP
ASP.NET jQuery 实例2 (表单中使用回车在TextBox之间向下移动)
2012/01/13 Javascript
jquery浏览器滚动加载技术实现方案
2014/06/03 Javascript
DOM操作一些常用的属性汇总
2015/03/13 Javascript
javascript实现的图片切割多块效果实例
2015/05/07 Javascript
表单元素值获取方式js及java方式的简单实例
2016/10/15 Javascript
jQuery插件echarts实现的去掉X轴、Y轴和网格线效果示例【附demo源码下载】
2017/03/04 Javascript
node.js连接MongoDB数据库的2种方法教程
2017/05/17 Javascript
Vue-cli-webpack搭建斗鱼直播步骤详解
2017/11/17 Javascript
VueJs 搭建Axios接口请求工具
2017/11/20 Javascript
把vue-router和express项目部署到服务器的方法
2018/02/21 Javascript
详解如何使用babel进行es6文件的编译
2018/05/29 Javascript
echarts设置图例颜色和地图底色的方法实例
2018/08/01 Javascript
小程序云开发如何实现图片上传及发表文字
2019/05/17 Javascript
IDEA配置jQuery, $符号不再显示黄色波浪线的问题
2020/10/09 jQuery
[05:45]Ti4观战指南(下)
2014/07/07 DOTA
python实现跨文件全局变量的方法
2014/07/07 Python
使用grappelli为django admin后台添加模板
2014/11/18 Python
Python中操作符重载用法分析
2016/04/29 Python
TF-IDF算法解析与Python实现方法详解
2017/11/16 Python
Python实现调度算法代码详解
2017/12/01 Python
pandas series序列转化为星期几的实例
2018/04/11 Python
python解析多层json操作示例
2019/12/30 Python
Python函数默认参数常见问题及解决方案
2020/03/26 Python
Keras load_model 导入错误的解决方式
2020/06/09 Python
CSS3实现点击放大的动画实例代码
2017/02/27 HTML / CSS
详解通过变换矩阵实现canvas的缩放功能
2019/01/14 HTML / CSS
俄罗斯游戏商店:Buka
2020/03/01 全球购物
JD Sports荷兰:英国领先的运动时尚零售商
2020/03/13 全球购物
Java如何支持I18N?
2016/10/31 面试题
合同意向书范本
2014/07/30 职场文书
分公司总经理岗位职责
2014/07/30 职场文书
财务总监岗位职责
2015/02/03 职场文书
电信营业员岗位职责
2015/04/14 职场文书
小学英语课教学反思
2016/02/15 职场文书