本文实例为大家分享了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); }) } };
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍纯js实现图片匀速淡入淡出效果,包括了纯js实现图片匀速淡入淡出效果的使用技巧和注意事项,需要的朋友参考一下 图片匀速淡入淡出效果如下: 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
本文向大家介绍JS实现淡入淡出图片效果的方法分析,包括了JS实现淡入淡出图片效果的方法分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JS实现淡入淡出图片效果的方法。分享给大家供大家参考,具体如下: 效果:鼠标移入时,图片由半透明逐渐变成清晰,移出时,由清晰变为半透明 分析:用变量来储存透明度,因为元素.style.alpha不能直接增加或减少 核心代码: 更多关于JavaScript
本文向大家介绍jQuery实现图片文字淡入淡出效果,包括了jQuery实现图片文字淡入淡出效果的使用技巧和注意事项,需要的朋友参考一下 本实例主要讲解了jquery仿新浪微博图片文字列表上下淡进淡出间歇上下滚动效果,分享给大家供大家参考,具体内容如下 1、效果及功能说明 仿新浪微博图片文字列表上下淡进淡出间歇上下滚动 2、实现原理 首先要设定div内只能显示4个图片那么多出来的图片会自动隐藏然后在
本文向大家介绍js如何实现淡入淡出效果,包括了js如何实现淡入淡出效果的使用技巧和注意事项,需要的朋友参考一下 淡入淡出效果,在日常项目中经常用到,可惜原生JS没有类似的方法,而有时小的页面并不值得引入一个jQuery库,所以就自己写了一个,已封装,有用得着的朋友,可以直接使用。代码中另附有一个设置元素透明度的方法, 是按IE规则(0~100)设置, 若改成标准设置方法(0.00~1.00),,下
本文向大家介绍原生js和jquery实现图片轮播淡入淡出效果,包括了原生js和jquery实现图片轮播淡入淡出效果的使用技巧和注意事项,需要的朋友参考一下 图片轮播有很多种方式,这里采用其中的 淡入淡出形式 js原生和jQuery都可以实现,jquery因为封装了很多用法,所以用起来就简单许多,转换成js使用,其实也就是用js原生模拟出这些用法。 但不管怎样,构造一个最基本的表现层是必须的 简单的
本文向大家介绍jquery实现淡入淡出轮播图效果,包括了jquery实现淡入淡出轮播图效果的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了jquery实现淡入淡出轮播图的具体代码,供大家参考,具体内容如下 如题所述,直接上代码 其实淡入淡出轮播图的核心思想就是获取到当前的索引,根据索引找出图片的索引然后更改索引达到一个图片显示 其他图片消失 然后轮流交替进行的。最主要的核心思想在上面