*新闻详情页*/>
序言
今日逛闲鱼的情况下观查到每行的高宽比并不是同样的,经掌握才了解原先这是1种瀑布流合理布局,觉得挺成心思,因而决策科学研究1下,在网络上也找了1些计划方案,完成瀑布流大约有3种方法。
1、JS 完成瀑布流
思路剖析
编码完成
<!DOCTYPE html> <html> <head> <style> .box { width: 100%; position:relative; } .item { position: absolute; } .item img{ width: 100%; height:100%; } </style> </head> <body> <div class="box"> <div class="item"> <img src="banner.jpg" alt="" /> </div> <div class="item"> <img src="show.jpg" alt="" /> </div> <div class="item"> <img src="cloth.jpg" alt="" /> </div> <div class="item"> <img src="banner.jpg" alt="" /> </div> <div class="item"> <img src="show.jpg" alt="" /> </div> <div class="item"> <img src="cloth.jpg" alt="" /> </div> <div class="item"> <img src="banner.jpg" alt="" /> </div> <div class="item"> <img src="show.jpg" alt="" /> </div> <div class="item"> <img src="cloth.jpg" alt="" /> </div> <div class="item"> <img src="show.jpg" alt="" /> </div> <div class="item"> <img src="cloth.jpg" alt="" /> </div> <div class="item"> <img src="banner.jpg" alt="" /> </div> </div> </body> <script src="jquery.min.js"></script> <script> function waterFall() { // 1 明确照片的宽度 - 翻转条宽度 var pageWidth = getClient().width⑻; var columns = 3; //3列 var itemWidth = parseInt(pageWidth/columns); //获得item的宽度 $(".item").width(itemWidth); //设定到item的宽度 var arr = []; $(".box .item").each(function(i){ var height = $(this).find("img").height(); if (i < columns) { // 2 第1行按顺序合理布局 $(this).css({ top:0, left:(itemWidth) * i+20*i, }); //将行高push到数字能量数组 arr.push(height); } else { // 别的行 // 3 寻找数字能量数组中最少高宽比 和 它的数据库索引 var minHeight = arr[0]; var index = 0; for (var j = 0; j < arr.length; j++) { if (minHeight > arr[j]) { minHeight = arr[j]; index = j; } } // 4 设定下1行的第1个盒子部位 // top值便是最少列的高宽比 $(this).css({ top:arr[index]+30,//设定30的间距 left:$(".box .item").eq(index).css("left") }); // 5 改动最少列的高宽比 // 最少列的高宽比 = 当今自身的高宽比 + 拼接过来的高宽比 arr[index] = arr[index] + height+30;//设定30的间距 } }); } //clientWidth 解决适配性 function getClient() { return { width: window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth, height: window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight } } // 网页页面规格更改时即时开启 window.onresize = function() { //再次界定瀑布流 waterFall(); }; //原始化 window.onload = function(){ //完成瀑布流 waterFall(); } </script> </html>
实际效果以下
2、column 多行合理布局完成瀑布流
思路剖析:
column 完成瀑布流关键依靠两个特性。
1个是 column-count 特性,是分成是多少列。
1个是 column-gap 特性,是设定列与列之间的间距。
编码完成:
<!DOCTYPE html> <html> <head> <style> .box { margin: 10px; column-count: 3; column-gap: 10px; } .item { margin-bottom: 10px; } .item img{ width: 100%; height:100%; } </style> </head> <body> <div class="box"> <div class="item"> <img src="banner.jpg" alt="" /> </div> <div class="item"> <img src="show.jpg" alt="" /> </div> <div class="item"> <img src="cloth.jpg" alt="" /> </div> <div class="item"> <img src="banner.jpg" alt="" /> </div> <div class="item"> <img src="show.jpg" alt="" /> </div> <div class="item"> <img src="cloth.jpg" alt="" /> </div> <div class="item"> <img src="banner.jpg" alt="" /> </div> <div class="item"> <img src="show.jpg" alt="" /> </div> <div class="item"> <img src="cloth.jpg" alt="" /> </div> <div class="item"> <img src="show.jpg" alt="" /> </div> <div class="item"> <img src="cloth.jpg" alt="" /> </div> <div class="item"> <img src="banner.jpg" alt="" /> </div> </div> </body>
实际效果以下:
3、flex 延展性合理布局完成瀑布流
思路剖析:
flex 完成瀑布流必须将最外层元素设定为 display: flex,即横向排序。随后根据设定 flex-flow:column wrap 使其换行。设定 height: 100vh 填充显示屏的高宽比,来容下子元素。每列的宽度能用 calc 涵数来设定,即 width: calc(100%/3 - 20px)。分为等宽的 3 列减掉上下两遍的 margin 间距。
编码完成:
<!DOCTYPE html> <html> <head> <style> .box { display: flex; flex-flow:column wrap; height: 100vh; } .item { margin: 10px; width: calc(100%/3 - 20px); } .item img{ width: 100%; height:100%; } </style> </head> <body> <div class="box"> <div class="item"> <img src="banner.jpg" alt="" /> </div> <div class="item"> <img src="show.jpg" alt="" /> </div> <div class="item"> <img src="cloth.jpg" alt="" /> </div> <div class="item"> <img src="banner.jpg" alt="" /> </div> <div class="item"> <img src="show.jpg" alt="" /> </div> <div class="item"> <img src="cloth.jpg" alt="" /> </div> <div class="item"> <img src="banner.jpg" alt="" /> </div> <div class="item"> <img src="show.jpg" alt="" /> </div> <div class="item"> <img src="cloth.jpg" alt="" /> </div> <div class="item"> <img src="show.jpg" alt="" /> </div> <div class="item"> <img src="cloth.jpg" alt="" /> </div> <div class="item"> <img src="banner.jpg" alt="" /> </div> </div> </body>
实际效果以下:
4、3种方法比照
假如只是简易的网页页面展现,可使用 column 多栏合理布局和 flex 延展性合理布局。假如必须动态性加上数据信息,或动态性设定列数,就必须应用到 JS + jQuery。
以上便是本文的所有內容,期待对大伙儿的学习培训有一定的协助,也期待大伙儿多多适用脚本制作之家。
Copyright © 2002-2020 在线网页制作_建网页_个人简介网页制作_简单网页_建立网页 版权所有 (网站地图) 粤ICP备10235580号