Ionic3实现图片瀑布流布局

瀑布流布局是比较流行的一种网站页面布局,视觉表现为参差不齐的多栏布局,随着页面滚动条向下滚动,这种布局还会不断加载数据块并附加至当前尾部。

瀑布流布局一般使用在网页中,在移动端用的比较少但是也不可缺。下面就介绍一下如何在ionic3中使用瀑布流布局。

首先创建一个项目,这里不多做介绍。我们用about这个模块来进行瀑布流的开发。

这里先介绍一下实现的流程:

我们先要定义一个container,在container中存在有多个BoxBox里面放置图片

1、首先获取container中的所有Box

2、获取Box的宽度和屏幕的宽度。

3、获取在当前屏幕宽度下一行可以放置多少个Box

4、将所有的Box的高度放到一个数组当中。

5、遍历数组,获取到第一行中最高度最小的Box

6、遍历数组的下标到达第二行的时候将第二排的首元素放在第一行的高度最低的元素下面。(比如一行放了三个Box,其中第三个高度最低,那么第四个就放在第三个Box的下面。)

7、将元素放在最低元素下面后,则将第三个元素和第四个元素高度相加成为一个新的第三个元素,同样重复即可实现。

下面是详细代码

about.html

rush:xhtml;">
Box" *ngFor="let image of img_data">
Box_img"> {{image.src}}

about.scss

rush:css;"> page-about { ion-content { #container { position: relative; .Box { padding: 5px; float: left; .Box_img { padding: 5px; border: 1px solid #cccccc; Box-shadow: 0 0 5px #ccc; border-radius: 5px; img { width: 150px!important; height: auto; } } } } } }

about.ts

rush:js;"> import { Component } from '@angular/core'; import { NavController,IonicPage } from 'ionic-angular'; @IonicPage({ name: 'about' }) @Component({ selector: 'page-about',templateUrl: 'about.html' }) export class AboutPage { img_data = [{ src: "assets/images/a.jpg" },{ src: "assets/images/b.jpg" },{ src: "assets/images/c.jpg" },{ src: "assets/images/d.jpg" },{ src: "assets/images/e.jpg" },{ src: "assets/images/f.jpg" },{ src: "assets/images/g.jpg" },{ src: "assets/images/h.jpg" },{ src: "assets/images/i.jpg" },{ src: "assets/images/j.jpg" },{ src: "assets/images/k.jpg" },{ src: "assets/images/l.jpg" },{ src: "assets/images/m.jpg" },{ src: "assets/images/n.jpg" },{ src: "assets/images/o.jpg" }] constructor(public navCtrl: NavController) {

}

ngAfterViewInit() {

}
ionViewWillEnter() {
this.getNode();
}
getNode() {
let parentNode = document.getElementById("container");
let childNodeArray: any = parentNode.getElementsByClassName("Box");
let screenWidth = document.documentElement.clientWidth;
let childWidth = childNodeArray[0].offsetWidth;
let num = Math.floor(screenWidth / childWidth); //获得一排摆的个数 用Math.floor()转换为整数
parentNode.style.csstext = "width:" + childWidth * num + "px; margin:0 auto"; //固定container的宽并设置居中
this.setimagePosition(num,childNodeArray);
}

setimagePosition(num,childArray) {
var imgHeightArray = [];//定义数组用于存放所有图片的高度
for (var i = 0; i < childArray.length; i++) { //遍历所有图片
if (i < num) {
imgHeightArray[i] = childArray[i].offsetHeight; //取得第一排图片的高度
} else {
var minHeight = Math.min.apply(null,imgHeightArray); //获取第一排图片中高度最小的图片
var minIndex = this.getMinHeight(imgHeightArray,minHeight); //函数获得高度最小的图片的位置
childArray[i].style.position = "absolute"; //绝对定位图片
childArray[i].style.top = minHeight + "px"; //图片距顶部像素
childArray[i].style.left = childArray[minIndex].offsetLeft + "px"; //图片距左的像素
imgHeightArray[minIndex] = imgHeightArray[minIndex] + childArray[i].offsetHeight; //将最低高度的Box的高度加上它下方的Box高度
}
}
}

getMinHeight(imgHeightArray,minHeight) {
for (var i in imgHeightArray) {
if (imgHeightArray[i] == minHeight) { //循环所有数组的高度 让它等于最小图片的高度 返回i值
return i;
}
}
}
//这里是借助ionic的上拉加载代替网页的滚动监听实现加载更多
doInfinite(infiniteScroll) {
let parentNode = document.getElementById("container");
for (var i = 0; i < this.img_data.length; i++) {
let divNode = document.createElement("div"); //创建div节点
divNode.className = "box";//为节点添加box类名
parentNode.appendChild(divNode);//添加根元素
let subDivNode = document.createElement("div");//创建节点
subDivNode.className = "box_img";//为节点添加类名
divNode.appendChild(subDivNode);//添加根元素
var img = document.createElement("img");//创建节点
img.src = this.img_data[i].src;//图片加载路径
subDivNode.appendChild(img);//添加根元素
}
this.getNode();
setTimeout(() => { infiniteScroll.complete() },1000);
}
}

最终效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...