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,🍪苏苏的码云~

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...