CSS 鼠标悬停时让父元素和子元素以不同的方式进行变换

要在鼠标悬停时让父元素和子元素以不同的方式进行变换(transform),可以分别设置它们的 transform 属性,并使用 transition 来实现平滑的效果。以下是一个示例,展示了如何实现这一效果。

HTML 结构

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Parent and Child Transform on Hover</title>
<link rel="stylesheet" href="styles.css">
</head>
<body>
<div class="parent">
    <div class="child">
        <img src="your-image.jpg" alt="Sample Image">
    </div>
</div>
</body>
</html>

CSS 样式

css 复制代码
/* styles.css */
.parent {
    width: 300px; /* 根据需要调整 */
    height: 300px; /* 根据需要调整 */
    overflow: hidden; /* 确保内容不会溢出容器 */
    background-color: #f0f0f0; /* 可选背景色 */
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s ease-in-out; /* 平滑过渡效果 */
}

.child {
    width: 100%;
    height: 100%;
    transition: transform 0.3s ease-in-out; /* 平滑过渡效果 */
}

.parent:hover {
    transform: rotate(10deg); /* 父元素旋转10度 */
}

.parent:hover .child {
    transform: scale(1.2); /* 子元素放大1.2倍 */
}

.child img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* 确保图片填充整个子元素 */
}

解释

  1. HTML:

    • 创建一个包含子元素的父元素 div
    • 子元素 div 包含一张图片。
  2. CSS:

    • .parent 类定义了父元素的样式,包括宽度、高度、背景色和居中对齐。overflow: hidden 确保内容不会溢出容器。
    • .child 类定义了子元素的样式,包括宽度、高度和过渡效果。
    • .parent:hover 类定义了鼠标悬停时父元素的变换效果,这里是旋转10度。
    • .parent:hover .child 类定义了鼠标悬停时子元素的变换效果,这里是放大1.2倍。
    • .child img 类确保图片填充整个子元素,并使用 object-fit: cover 使图片适应子元素的尺寸。

通过这种方式,你可以实现鼠标悬停时父元素和子元素以不同方式进行变换的效果。你可以根据需要调整变换的具体参数,如旋转角度和缩放比例。

相关推荐
是上好佳佳佳呀37 分钟前
【前端(十三)】JavaScript 数组与字符串笔记
前端·javascript·笔记
巴沟旮旯儿38 分钟前
vite项目配置文件和打包
前端·设计模式
彩票管理中心秘书长1 小时前
Pinia 插件架构与组合式函数:如何让你的 Store 长出“超能力”
前端
彩票管理中心秘书长1 小时前
Pinia 比 Vuex 强在哪?我用同一个模块写了两种实现,你自己看
前端
yingyima1 小时前
用 Cron 加 Webhook 打通自动化工作的任督二脉
前端
JackieDYH1 小时前
CSS Flexbox 与 Grid 的默认行为-布局的底层机制
前端·css·html
彩票管理中心秘书长1 小时前
E2E测试入门:别让用户帮你点鼠标了,找个机器人替你打工吧
前端
菜蒙爱学习1 小时前
【Markdown】可用的所有 HTML 标准颜色
前端·html
小宋的踩坑日记1 小时前
全网最全!Tailwind/Unocss 类名速查表,前端开发必备神器!
css·小程序·前端框架
里欧跑得慢1 小时前
CSS 嵌套:编写更优雅的样式代码
前端·css·flutter·web