来源:未知 时间:2024-06-01 23:31 作者:小飞侠 阅读:次
[导读] 效果图如下: 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> 思路: 
 		.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