mirror of
https://github.com/201206030/novel.git
synced 2025-04-27 07:30:50 +00:00
增加图片懒加载机制,提供页面加载速度
This commit is contained in:
parent
8706168b94
commit
11b9dca672
180
novel-front/src/main/resources/static/js/lazyload.js
Normal file
180
novel-front/src/main/resources/static/js/lazyload.js
Normal file
@ -0,0 +1,180 @@
|
|||||||
|
/*!
|
||||||
|
* Lazy Load - JavaScript plugin for lazy loading images
|
||||||
|
*
|
||||||
|
* Copyright (c) 2007-2019 Mika Tuupola
|
||||||
|
*
|
||||||
|
* Licensed under the MIT license:
|
||||||
|
* http://www.opensource.org/licenses/mit-license.php
|
||||||
|
*
|
||||||
|
* Project home:
|
||||||
|
* https://appelsiini.net/projects/lazyload
|
||||||
|
*
|
||||||
|
* Version: 2.0.0-rc.2
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
(function (root, factory) {
|
||||||
|
if (typeof exports === "object") {
|
||||||
|
module.exports = factory(root);
|
||||||
|
} else if (typeof define === "function" && define.amd) {
|
||||||
|
define([], factory);
|
||||||
|
} else {
|
||||||
|
root.LazyLoad = factory(root);
|
||||||
|
}
|
||||||
|
}) (typeof global !== "undefined" ? global : this.window || this.global, function (root) {
|
||||||
|
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
if (typeof define === "function" && define.amd){
|
||||||
|
root = window;
|
||||||
|
}
|
||||||
|
|
||||||
|
const defaults = {
|
||||||
|
src: "data-src",
|
||||||
|
srcset: "data-srcset",
|
||||||
|
selector: ".lazyload",
|
||||||
|
root: null,
|
||||||
|
rootMargin: "0px",
|
||||||
|
threshold: 0
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Merge two or more objects. Returns a new object.
|
||||||
|
* @private
|
||||||
|
* @param {Boolean} deep If true, do a deep (or recursive) merge [optional]
|
||||||
|
* @param {Object} objects The objects to merge together
|
||||||
|
* @returns {Object} Merged values of defaults and options
|
||||||
|
*/
|
||||||
|
const extend = function () {
|
||||||
|
|
||||||
|
let extended = {};
|
||||||
|
let deep = false;
|
||||||
|
let i = 0;
|
||||||
|
let length = arguments.length;
|
||||||
|
|
||||||
|
/* Check if a deep merge */
|
||||||
|
if (Object.prototype.toString.call(arguments[0]) === "[object Boolean]") {
|
||||||
|
deep = arguments[0];
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Merge the object into the extended object */
|
||||||
|
let merge = function (obj) {
|
||||||
|
for (let prop in obj) {
|
||||||
|
if (Object.prototype.hasOwnProperty.call(obj, prop)) {
|
||||||
|
/* If deep merge and property is an object, merge properties */
|
||||||
|
if (deep && Object.prototype.toString.call(obj[prop]) === "[object Object]") {
|
||||||
|
extended[prop] = extend(true, extended[prop], obj[prop]);
|
||||||
|
} else {
|
||||||
|
extended[prop] = obj[prop];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Loop through each object and conduct a merge */
|
||||||
|
for (; i < length; i++) {
|
||||||
|
let obj = arguments[i];
|
||||||
|
merge(obj);
|
||||||
|
}
|
||||||
|
|
||||||
|
return extended;
|
||||||
|
};
|
||||||
|
|
||||||
|
function LazyLoad(images, options) {
|
||||||
|
this.settings = extend(defaults, options || {});
|
||||||
|
this.images = images || document.querySelectorAll(this.settings.selector);
|
||||||
|
this.observer = null;
|
||||||
|
this.init();
|
||||||
|
}
|
||||||
|
|
||||||
|
LazyLoad.prototype = {
|
||||||
|
init: function() {
|
||||||
|
|
||||||
|
/* Without observers load everything and bail out early. */
|
||||||
|
if (!root.IntersectionObserver) {
|
||||||
|
this.loadImages();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
let self = this;
|
||||||
|
let observerConfig = {
|
||||||
|
root: this.settings.root,
|
||||||
|
rootMargin: this.settings.rootMargin,
|
||||||
|
threshold: [this.settings.threshold]
|
||||||
|
};
|
||||||
|
|
||||||
|
this.observer = new IntersectionObserver(function(entries) {
|
||||||
|
Array.prototype.forEach.call(entries, function (entry) {
|
||||||
|
if (entry.isIntersecting) {
|
||||||
|
self.observer.unobserve(entry.target);
|
||||||
|
let src = entry.target.getAttribute(self.settings.src);
|
||||||
|
let srcset = entry.target.getAttribute(self.settings.srcset);
|
||||||
|
if ("img" === entry.target.tagName.toLowerCase()) {
|
||||||
|
if (src) {
|
||||||
|
entry.target.src = src;
|
||||||
|
}
|
||||||
|
if (srcset) {
|
||||||
|
entry.target.srcset = srcset;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
entry.target.style.backgroundImage = "url(" + src + ")";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}, observerConfig);
|
||||||
|
|
||||||
|
Array.prototype.forEach.call(this.images, function (image) {
|
||||||
|
self.observer.observe(image);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
loadAndDestroy: function () {
|
||||||
|
if (!this.settings) { return; }
|
||||||
|
this.loadImages();
|
||||||
|
this.destroy();
|
||||||
|
},
|
||||||
|
|
||||||
|
loadImages: function () {
|
||||||
|
if (!this.settings) { return; }
|
||||||
|
|
||||||
|
let self = this;
|
||||||
|
Array.prototype.forEach.call(this.images, function (image) {
|
||||||
|
let src = image.getAttribute(self.settings.src);
|
||||||
|
let srcset = image.getAttribute(self.settings.srcset);
|
||||||
|
if ("img" === image.tagName.toLowerCase()) {
|
||||||
|
if (src) {
|
||||||
|
image.src = src;
|
||||||
|
}
|
||||||
|
if (srcset) {
|
||||||
|
image.srcset = srcset;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
image.style.backgroundImage = "url('" + src + "')";
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
destroy: function () {
|
||||||
|
if (!this.settings) { return; }
|
||||||
|
this.observer.disconnect();
|
||||||
|
this.settings = null;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
root.lazyload = function(images, options) {
|
||||||
|
return new LazyLoad(images, options);
|
||||||
|
};
|
||||||
|
|
||||||
|
if (root.jQuery) {
|
||||||
|
const $ = root.jQuery;
|
||||||
|
$.fn.lazyload = function (options) {
|
||||||
|
options = options || {};
|
||||||
|
options.attribute = options.attribute || "data-src";
|
||||||
|
new LazyLoad($.makeArray(this), options);
|
||||||
|
return this;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
return LazyLoad;
|
||||||
|
});
|
@ -115,7 +115,7 @@
|
|||||||
<a th:href="'/book/'+ ${book.id} + '.html'+ ${token!=null?'?token='+token:''}">
|
<a th:href="'/book/'+ ${book.id} + '.html'+ ${token!=null?'?token='+token:''}">
|
||||||
<div class="layui-col-xs6 layui-col-sm3 layui-col-md2 layui-col-lg2" style="text-align: center">
|
<div class="layui-col-xs6 layui-col-sm3 layui-col-md2 layui-col-lg2" style="text-align: center">
|
||||||
<img align="center"
|
<img align="center"
|
||||||
th:src="${book.picUrl}"/>
|
class="lazyload" th:attr="data-src=${book.picUrl}"/>
|
||||||
</div>
|
</div>
|
||||||
</a>
|
</a>
|
||||||
<div style="padding: 20px" class="layui-col-xs6 layui-col-sm8 layui-col-md8 layui-col-lg8">
|
<div style="padding: 20px" class="layui-col-xs6 layui-col-sm8 layui-col-md8 layui-col-lg8">
|
||||||
@ -156,8 +156,10 @@
|
|||||||
</body>
|
</body>
|
||||||
|
|
||||||
<div th:replace="common/js :: js"></div>
|
<div th:replace="common/js :: js"></div>
|
||||||
|
<script src="/js/lazyload.js"></script>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
lazyload();
|
||||||
layui.use('laypage', function () {
|
layui.use('laypage', function () {
|
||||||
var laypage = layui.laypage;
|
var laypage = layui.laypage;
|
||||||
|
|
||||||
|
@ -124,7 +124,7 @@
|
|||||||
<a th:href="'/book/' + ${recBook.id} + '.html'">
|
<a th:href="'/book/' + ${recBook.id} + '.html'">
|
||||||
<div style="padding: 1%" class="layui-col-xs4 layui-col-sm4 layui-col-md4 layui-col-lg4">
|
<div style="padding: 1%" class="layui-col-xs4 layui-col-sm4 layui-col-md4 layui-col-lg4">
|
||||||
<img style=" width:80%; height:auto; max-width:100%; max-height:100%;"
|
<img style=" width:80%; height:auto; max-width:100%; max-height:100%;"
|
||||||
th:src="${recBook.picUrl}"/>
|
class="lazyload" th:attr="data-src=${recBook.picUrl}" />
|
||||||
<br/>
|
<br/>
|
||||||
<span th:text="${recBook.bookName}"></span>
|
<span th:text="${recBook.bookName}"></span>
|
||||||
|
|
||||||
@ -146,7 +146,7 @@
|
|||||||
<a th:href="'/book/' + ${hotBook.id} + '.html'">
|
<a th:href="'/book/' + ${hotBook.id} + '.html'">
|
||||||
<div class="layui-col-xs5 layui-col-sm4 layui-col-md4 layui-col-lg4">
|
<div class="layui-col-xs5 layui-col-sm4 layui-col-md4 layui-col-lg4">
|
||||||
<img style=" width:100px; height:125px;"
|
<img style=" width:100px; height:125px;"
|
||||||
th:src="${hotBook.picUrl}"/>
|
class="lazyload" th:attr="data-src=${hotBook.picUrl}"/>
|
||||||
</div>
|
</div>
|
||||||
<div class="layui-col-xs5 layui-col-sm6 layui-col-md6 layui-col-lg6">
|
<div class="layui-col-xs5 layui-col-sm6 layui-col-md6 layui-col-lg6">
|
||||||
<ul>
|
<ul>
|
||||||
@ -239,9 +239,11 @@
|
|||||||
</div>
|
</div>
|
||||||
<div th:replace="common/js :: js">
|
<div th:replace="common/js :: js">
|
||||||
</div>
|
</div>
|
||||||
|
<script src="/js/lazyload.js"></script>
|
||||||
|
|
||||||
<script src="/js/wap_collect.js"></script>
|
<script src="/js/wap_collect.js"></script>
|
||||||
<script>
|
<script>
|
||||||
|
lazyload();
|
||||||
(function () {
|
(function () {
|
||||||
var bp = document.createElement('script');
|
var bp = document.createElement('script');
|
||||||
var curProtocol = window.location.protocol.split(':')[0];
|
var curProtocol = window.location.protocol.split(':')[0];
|
||||||
|
@ -130,7 +130,7 @@
|
|||||||
<a th:href="'/book/'+ ${book.id} + '.html'">
|
<a th:href="'/book/'+ ${book.id} + '.html'">
|
||||||
<div class="layui-col-xs6 layui-col-sm3 layui-col-md2 layui-col-lg2" style="text-align: center">
|
<div class="layui-col-xs6 layui-col-sm3 layui-col-md2 layui-col-lg2" style="text-align: center">
|
||||||
<img align="center"
|
<img align="center"
|
||||||
th:src="${book.picUrl}"/>
|
class="lazyload" th:attr="data-src=${book.picUrl}"/>
|
||||||
</div>
|
</div>
|
||||||
</a>
|
</a>
|
||||||
<div style="padding: 20px" class="layui-col-xs6 layui-col-sm8 layui-col-md8 layui-col-lg8">
|
<div style="padding: 20px" class="layui-col-xs6 layui-col-sm8 layui-col-md8 layui-col-lg8">
|
||||||
@ -171,6 +171,7 @@
|
|||||||
</body>
|
</body>
|
||||||
|
|
||||||
<div th:replace="common/js :: js"></div>
|
<div th:replace="common/js :: js"></div>
|
||||||
|
<script src="/js/lazyload.js"></script>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
layui.use('laypage', function () {
|
layui.use('laypage', function () {
|
||||||
|
@ -154,7 +154,7 @@
|
|||||||
<a th:href="'/book/'+ ${book.id} + '.html'">
|
<a th:href="'/book/'+ ${book.id} + '.html'">
|
||||||
<div class="layui-col-xs6 layui-col-sm3 layui-col-md2 layui-col-lg2" style="text-align: center">
|
<div class="layui-col-xs6 layui-col-sm3 layui-col-md2 layui-col-lg2" style="text-align: center">
|
||||||
<img align="center"
|
<img align="center"
|
||||||
th:src="${book.picUrl}"/>
|
class="lazyload" th:attr="data-src=${book.picUrl}"/>
|
||||||
</div>
|
</div>
|
||||||
</a>
|
</a>
|
||||||
<div style="padding: 20px" class="layui-col-xs6 layui-col-sm8 layui-col-md8 layui-col-lg8">
|
<div style="padding: 20px" class="layui-col-xs6 layui-col-sm8 layui-col-md8 layui-col-lg8">
|
||||||
@ -195,6 +195,7 @@
|
|||||||
</body>
|
</body>
|
||||||
|
|
||||||
<div th:replace="common/js :: js"></div>
|
<div th:replace="common/js :: js"></div>
|
||||||
|
<script src="/js/lazyload.js"></script>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
layui.use('laypage', function () {
|
layui.use('laypage', function () {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user