JavaScript实现简单的图片瀑布流插件

更新日期: 2020-03-08阅读: 2.4k标签: 瀑布流

JavaScript实现简单的图片瀑布流插件 

this.myPlugin = this.myPlugin || {};

/**
* 制作图片瀑布流
*/
this.myPlugin.createImgWaterfall = function (option) {
var defaultOption = {
minGap: 10, //最小间隙
imgSrcs: [], //存储图片路径的数组
imgWidth: 200, //单张图片的宽度
container: document.body //存储图片瀑布流的容器
};
//将传入的参数option和默认的配置defaultOption合并
option = Object.assign({}, defaultOption, option);
var imgs = []; //存放所有的图片元素的数组

//处理父元素
handleParent();

//创建图片元素
createImgs();

//将setImgPosition设置为防抖函数
//所有的图片加载完成后,隔一段时间执行setImgPosition函数
var viewDebounce = debounce(setImgPosition, 300);
window.onresize = viewDebounce; //浏览器视口尺寸改变,则重新设置图片位置信息

/**
* 检查父元素是否是定位元素
* 不是定位元素,要转变为定位元素
*/
function handleParent() {
var style = getComputedStyle(option.container);
if (style.position === "static") { //没有定位
option.container.style.position = "relative"; //使用相对定位
}
}

/**
* 为每一张图片创建一个img元素
* 并且设置img元素的样式
*/
function createImgs() {
var imgDebounce = debounce(setImgPosition, 300);
for (var i = 0; i < option.imgSrcs.length; i++) {
var img = document.createElement("img");
img.src = option.imgSrcs[i]; //设置图片路径
img.style.width = option.imgWidth + "px"; //设置图片宽度
img.style.position = "absolute"; //设置图片绝对定位
img.style.transition = ".5s"; //设置图片过渡时间
imgs.push(img);
img.onload = imgDebounce; //等图片加载完毕,设置图片位置信息
option.container.appendChild(img); //加入图片容器
}
}

/**
* 设置每个图片元素的位置信息
*/
function setImgPosition() {
//获取图片的水平信息
var info = getHorizontalInfo();
console.log(info);
var arr = new Array(info.imgNum); //存放下一行,每张图片的top值
arr.fill(0); //数组各项值填充为0
imgs.forEach(function (img) {
//设置每张图片的位置信息
var minTop = Math.min.apply(null, arr); //找到数组中最小的top值
img.style.top = minTop + "px"; //设置图片的top值
var index = arr.indexOf(minTop); //找到数组中最小值的下标
arr[index] += img.clientHeight + info.gap; //设置下张图片的top值
img.style.left = index * (option.imgWidth + info.gap) + "px"; //设置图片的left值
});
//所有图片位置设置好后,计算容器最终的高度
var maxTop = Math.max.apply(null, arr); //找到最大的top值
option.container.style.height = maxTop - info.gap + "px";
}

/**
* 获取图片的水平信息,包括
* 容器宽度:填充盒
* 一行可以放置图片的数量
* 图片与图片之间的水平和垂直空隙
*/
function getHorizontalInfo() {
var obj = {};
obj.containerWidth = option.container.clientWidth; //存放图片容器的宽度
//imgWidth*imgNum + minGab*(imgNum - 1) = containerWidth;
//图片宽度 * 图片数量 + 图片间的最小间隙*(图片数量-1) = 容器总宽度
//根据上面的公式变形后,得到一行可以放置的图片数量
obj.imgNum = (obj.containerWidth + option.minGap) / (option.imgWidth + option.minGap);
obj.imgNum = Math.floor(obj.imgNum); //图片数量要向下取整
//图片之间的间隙 = (容器总宽度 - 图片宽度*图片数量) / (图片数量 - 1)
obj.gap = (obj.containerWidth - option.imgWidth * obj.imgNum) / (obj.imgNum - 1);

return obj;
}

/**
* 函数防抖,过一段时间后,执行某个函数
*/
function debounce(callback, time) {
var timer = null; //计时器
console.log(timer);
return function () {
console.log(timer);
timer && clearTimeout(timer); //每次执行,重新计时
var args = arguments;
timer = setTimeout(function () {
callback.apply(null, args);
}, time);
}
}
};

myPlugin.js

功能:

1).可以自动根据浏览器视口宽度,改变图片瀑布流的宽度

2).添加了函数防抖功能

 

调用图片瀑布流插件:

<!DOCTYPE html>
<html lang="en">

<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.container {
border: 1px solid #000;
width: 90%;
margin: 0 auto;
}
</style>
</head>

<body>
<div class="container">

</div>
<script src="./js/myPlugin.js"></script>
<script>
var imgSrcs = [];
for(var i = 1; i <= 40; i++){
imgSrcs.push(`./image/${i}.jpg`);
}
myPlugin.createImgWaterfall({
imgSrcs: imgSrcs,
container: document.querySelector(".container") //存储图片瀑布流的容器
});
</script>
</body>

</html>

index.html


使用了40张图片的图片最后的效果



链接: https://fly63.com/article/detial/8887

vue实现瀑布流布局的组件/插件总汇

瀑布流作为当前比较流行的一种网页布局方式,在视觉上呈现出参差不齐、琳琅满目、唯美的视觉效果,该布局随着页面滚动,数据不断加载并附加至当前页面的尾部。这篇文章主要介绍关于vue框架中常使用的瀑布流组件

CSS3实现瀑布流布局

瀑布流布局是种常见的布局方式,常用于图片相关的样式展示,通过CSS3的多列(Multi-column)属性,可以简单的实现类似效果。设置外部容器多列列数(column-count)和列间距(column-gap)

js实现无限瀑布流

是一种常见的网页布局方式,在许多网站中我们都能看到“瀑布流”的效果,其特征是有网页视窗有多个高度不同宽度相同的“块”组成。因其样式酷似飞流直下的瀑布,故将这种布局方式称为瀑布流。

瀑布流的布局原理分析(纯CSS瀑布流与JS瀑布流)

瀑布流 又称瀑布流式布局,是比较流行的一种网站页面布局方式。即多行等宽元素排列,后面的元素依次添加到其后,等宽不等高,根据图片原比例缩放直至宽度达到我们的要求,依次按照规则放入指定位置。

万能瀑布流

常见的瀑布流实现大部分只适用于子块尺寸固定或内部有图片异步加载的情况。而对于子块有图片这种可能引起尺寸变化的情况,通常的做法是写死图片高度,或检测内部的 img 元素从而在 onload 事件中进行重排。

原生JS实现一个瀑布流插件

瀑布流布局中的图片有一个核心特点 —— 等宽不定等高,瀑布流布局在国内网网站都有一定规模的使用,比如pinterest、花瓣网等等。那么接下来就基于这个特点开始瀑布流探索之旅。

纯CSS瀑布流与JS瀑布流

又称瀑布流式布局,是比较流行的一种网站页面布局方式。即多行等宽元素排列,后面的元素依次添加到其后,等宽不等高,根据图片原比例缩放直至宽度达到我们的要求,依次按照规则放入指定位置。

vue实现网络图片瀑布流 + 下拉刷新 + 上拉加载更多

用vue来实现一个瀑布流效果,加载网络图片,同时有下拉刷新和上拉加载更多功能效果。然后针对这几个效果的实现,捋下思路:根据加载数据的顺序,依次追加标签展示效果;

小程序实现瀑布流和上拉加载

瀑布流又称瀑布流式布局,是比较流行的一种网站页面布局方式。视觉表现为参差不齐的多栏布局,即多行等宽元素排列,后面的元素依次添加到其后,等宽不等高。基本思路就是利用wx:if和数组的下标对2取余来判断是排在左列还是排在右列

css实现瀑布流布局

依赖 column 便可实现最简单实用的瀑布流布局,我这里前端框架用的是 Vue, 用其他的也一样,column-count: 3; 内容均分三份

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!