网站地图    收藏   

主页 > 前端 > css3 >

grid网格布局等比例缩放图片列表排版

来源:未知    时间:2023-08-17 13:20 作者:小飞侠 阅读:

[导读] 效果图如下: html代码如下: divclass=warpbox...divclass=warp-itemdivclass=imgboximgsrc=https://dingtalk.xiaohuazhuo.com/v1/api/board/thumb/64dc832cc1fb71424276d37f/div/div.../div 思路: 利用grid的弹性盒子等比例排版...

效果图如下:

新窗口打开:https://www.zixuephp.com/static/res/grid-test/

html代码如下:

	<div class="warpbox">
	        ...
		<div class="warp-item">
			<div class="imgbox">
				<img src="https://dingtalk.xiaohuazhuo.com/v1/api/board/thumb/64dc832cc1fb71424276d37f">
			</div>
		</div>
		...
	</div>

思路:

  1. 利用grid的弹性盒子等比例排版

		.warpbox{
			display: grid;
			grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
			grid-gap: 10px 5px;
		}

2. 给子盒子上加上定位,为了让接下来里面图片自适应,不得不做内填充 padding-top:100%~50%看需求,100%是正方形。

		.warpbox .warp-item{
			border: 1px solid #ff0000;
			box-sizing: border-box;
			display: flex;
			justify-content: center;
			align-items: center;
			position: relative;
			padding-top: 56%;
		}

3.图片上层套一层盒子,做定位(position),防止图片尺寸不一致导致外部布局不一致(flex等被撑开)

		.warpbox .warp-item .imgbox{
			position: absolute;
			left: 0;
			top: 0;
			right: 0;
			bottom: 0;
		    display: flex; // 要里面图片居中显示加上此特性
		    justify-content: center; // 要里面图片居中显示加上此特性
		    align-items: center; // 要里面图片居中显示加上此特性
		}

4. 最后针对图片缩放,有2套方案如下

		// 方案1
		.warpbox .warp-item img {
			max-width:100%;
			max-height: 100%;
		}
		// 方案2效果一致,object-fit是针对图片拉伸的特性,scale-down表示宽高谁要用谁。
		.warpbox .warp-item img {
			width:100%;
			height: 100%;
			object-fit: scale-down;
		}

详细教程请看下面。

grid基础教程:

Grid 布局即网格布局

display:grid 或 display:inline-grid 来创建一个网格容器


grid-template-columns 属性和 grid-template-rows 属性

grid-template-columns 属性设置列宽,grid-template-rows 属性设置行高,这两个属性在 Grid 布局中尤为重要,它们的值是有多种多样的


1、 repeat() 函数:可以简化重复的值

2、auto-fill 关键字:表示自动填充,让一行(或者一列)中尽可能的容纳更多的单元格。例如:

grid-template-columns: repeat(auto-fill, 200px);

3、fr 关键字:Grid

布局还引入了一个另外的长度单位来帮助我们创建灵活的网格轨道。fr

单位代表网格容器中可用空间的一等份。grid-template-columns: 200px 1fr 2fr 表示第一个列宽设置为

200px,后面剩余的宽度分为两部分,宽度分别为剩余宽度的 1/3 和 2/3。 例如:grid-template-columns:

200px 1fr 2fr;

4、minmax() 函数:我们有时候想给网格元素一个最小和最大的尺寸,minmax() 函数产生一个长度范围,表示长度就在这个范围之中都可以应用到网格项目中。它接受两个参数,分别为最小值和最大值。grid-template-columns: 1fr 1fr minmax(300px, 2fr) 的意思是,第三个列宽最少也是要 300px,但是最大不能大于第一第二列宽的两倍。

5、auto 关键字:由浏览器决定长度。通过 auto 关键字,我们可以轻易实现三列或者两列布局。grid-template-columns: 100px auto 100px 表示第一第三列为 100px,中间由浏览器决定长度,


grid-row-gap 属性、grid-column-gap 属性以及 grid-gap 属性

grid-row-gap 属性、grid-column-gap 属性分别设置行间距和列间距。grid-gap 属性是两者的简写形式。


grid-row-gap: 10px 表示行间距是 10px,grid-column-gap: 20px 表示列间距是 20px。grid-gap: 10px 20px 实现的效果是一样的


grid-template-areas 属性

grid-template-areas 属性用于定义区域,一个区域由一个或者多个单元格组成


一般这个属性跟网格元素的 grid-area 一起使用,我们在这里一起介绍。 grid-area 属性指定项目放在哪一个区域

grid-template-areas 属性用于定义区域,一个区域由一个或者多个单元格组成


一般这个属性跟网格元素的 grid-area 一起使用,我们在这里一起介绍。 grid-area 属性指定项目放在哪一个区域


grid-auto-flow 属性

grid-auto-flow: row dense,表示尽可能填满表格。 默认row,column


justify-items 属性、align-items 属性以及 place-items 属性

justify-items 属性设置单元格内容的水平位置(左中右),align-items 属性设置单元格的垂直位置(上中下)

.container {

justify-items: start | end | center | stretch;

align-items: start | end | center | stretch;

}


justify-content 属性、align-content 属性以及 place-content 属性

.container {

justify-content: start | end | center | stretch | space-around | space-between | space-evenly;

align-content: start | end | center | stretch | space-around | space-between | space-evenly;

}

space-around - 每个项目两侧的间隔相等。所以,项目之间的间隔比项目与容器边框的间隔大一倍

space-between - 项目与项目的间隔相等,项目与容器边框之间没有间隔

space-evenly - 项目与项目的间隔相等,项目与容器边框之间也是同样长度的间隔

stretch - 项目大小没有指定时,拉伸占据整个网格容器


grid-column-start 属性、grid-column-end 属性、grid-row-start 属性以及grid-row-end 属性

可以指定网格项目所在的四个边框,分别定位在哪根网格线,从而指定项目的位置


grid-column-start 属性:左边框所在的垂直网格线

grid-column-end 属性:右边框所在的垂直网格线

grid-row-start 属性:上边框所在的水平网格线

grid-row-end 属性:下边框所在的水平网格线


justify-self 属性、align-self 属性以及 place-self 属性

justify-self 属性设置单元格内容的水平位置(左中右),跟 justify-items 属性的用法完全一致,但只作用于单个项目


Grid 实战——实现响应式布局

fr 实现等分响应式


fr 等分单位,可以将容器的可用空间分成想要的多个等分空间。利用这个特性,我们能够轻易实现一个等分响应式。grid-template-columns: 1fr 1fr 1fr 表示容器分为三等分


repeat + auto-fit——固定列宽,改变列数量


repeat+auto-fit+minmax 去掉右侧空白

上面看到的效果中,右侧通常会留下空白,这是我们不希望看到的。如果列的宽度也能在某个范围内自适应就好了。minmax() 函数就帮助我们做到了这点。将 grid-template-columns: repeat(auto-fit, 200px) 改成 grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)) 表示列宽至少 200px,如果还有空余则一起等分


## repeat+auto-fit+minmax-span-dense 解决空缺问题

repeat+auto-fit+minmax-span-dense 解决空缺问题


.wrapper, .wrapper-1 {
margin: 50px;
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
grid-gap: 10px 20px;
grid-auto-rows: 50px;
}
.wrapper-1 {
grid-auto-flow: row dense;
}



自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号-1@版权所有www.zixuephp.com

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

添加评论