Grid 布局实现九宫格图片动画
创始人
2024-03-16 23:43:42
0

前言

👏Grid 布局实现九宫格,background-position设置背景图像起始位置,速速来Get吧~
🥇文末分享源代码。记得点赞+关注+收藏!

1.实现效果

在这里插入图片描述

2.实现步骤

  • 定义css变量:九宫格中每个宫格的长/宽为w,宫格之间的间距为gap;
:root {--w: 80px;--gap: 10px;
}
  • 父容器为正方形,宽/高为calc(var(–w) * 3 + var(–gap) * 2),设置为grid布局

在这里插入图片描述

//...共9个
.container {width: calc(var(--w) * 3 + var(--gap) * 2);height: calc(var(--w) * 3 + var(--gap) * 2);display: grid;border: 1px solid red;
}
.item {width: var(--w);height: var(--w);border: 1px solid red;
}
  • 父容器设置grid-template-columns和grid-template-rows

在这里插入图片描述

.container{+ grid-template-columns: repeat(3, var(--w));+ grid-template-rows: repeat(3, var(--w));
}
  • 设置九宫格水平/垂直方向均匀分布,place-content: space-between,但是在完成后续动画的时候,发现place-content无法实现过渡效果,遂放弃此用法

在这里插入图片描述

.container{+ place-content: space-between;
}
  • 使用gap,实现九宫格水平/垂直方向均匀分布

在这里插入图片描述

.container{- place-content: space-between;+ gap: var(--gap);/* gap省略了第二个值,浏览器认为第二个值等于第一个值 */
}
  • 每个宫格添加同一个背景图片,设置渐变边框,设置background-size为calc(var(–w) * 3),即一张完整九宫格的大小(不包含gap间距)

在这里插入图片描述

.item{border: 1px solid;border-image: linear-gradient(45deg, #293a53, #7cb1c5) 1;background-size: calc(var(--w) * 3) calc(var(--w) * 3);background-image: url("../img/card.jpg");
}
  • 为每个宫格设置不同的background-position,这里为了方便调试,可以将gap间距设置为0

background-position:
1.为每一个背景图片设置初始位置。这个位置是相对于由 background-origin 定义的位置图层的。
2.background-position 属性被指定为一个或多个 position值,用逗号隔开。
3.如果使用两个非关键字值,第一个值表示水平位置,第二个值表示垂直位置。
4.初始值为0% 0%,即水平和垂直方向在左上角

  • 设置宫格在x方向的位置

在这里插入图片描述

  • 为每个宫格定义css变量,–x表示需要进行偏移的倍数

在这里插入图片描述

.item{+ background-position-x: calc(var(--x) * 100%)
}
  • 设置宫格在y方向的位置

在这里插入图片描述

  • 为每个宫格定义css变量,–y表示需要进行偏移的倍数

在这里插入图片描述

.item{-  background-position-x: calc(var(--x) * 100%)-  background-position: calc(var(--x) * 100%) calc(var(--y) * 100%);
}
  • 将gap间距改回原来设置的参数

在这里插入图片描述

  • 父容器添加hover事件,hover时候添加drop-shadow投影,将gap间距设置为0,并去掉子元素的borer边框

在这里插入图片描述

.container:hover {filter: drop-shadow(0px 0px 20px #000);gap: 0;
}
.container:hover .item {border: none;
}
  • 父容器添加transition过渡效果,并设置九宫格水平垂直居中

在这里插入图片描述

.container{place-content: center;transition: all 0.5s;
}
  • 去掉多余的辅助边框等,就完成啦~
    在这里插入图片描述

3.实现代码


Grid 布局实现九宫格图片动画

4.写在最后🍒

看完本文如果觉得对你有一丢丢帮助,记得点赞+关注+收藏鸭 🍕
更多相关内容,关注🍥苏苏的bug,🍡苏苏的github,🍪苏苏的码云~

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...