CSS 3D变换,transform:translateZ()

transform:translateZ()是CSS 3D变换中的一个属性,用于控制元素在Z轴(前后方向)上的移动

功能:将元素沿Z轴(垂直于屏幕的方向)移动指定距离

translateZ(10px)=》元素向观察者方向凸起(靠近你)

translateZ(-50px)=》元素向屏幕内部凹陷(远离你)

视觉效果:

当元素在Z轴上移动时,会因透视(perspective)产生近大远小的立体效果

需要父元素或祖先元素设置perspective属性才能看到3D效果,否则无变化

关键点说明:

perspective的必要性:

父容器必须设置透视(如:perspective:500px),否则translateZ()的3D效果无法显现

perspective的值越小,3D效果越夸张(类似于广角镜头);值越大,效果越平缓

!注意,多次使用3D效果,会加重GPU性能

下面见代码:(实现类似的还可以直接使用transform: scale(1.1); /* 鼠标悬停时放大 */一样可以实现类似的效果)

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div style="margin-left: 100px;margin-top: 100px;">
        <img src="./left.png">
    </div>
</body>
<style>
    body{
        perspective: 500px; /* 必须设置透视距离 */
    }
    div{
        height: 400px;
        width: 200px;
        box-shadow: 0 4px 10px rgba(0, 0, 0, 0.5); /* 初始阴影 */
        cursor: pointer;
        transition: box-shadow 0.3s ease, transform 0.3s ease; /* 添加过渡效果 */
    }
    div:hover{
            box-shadow: 0 8px 20px rgba(0, 0, 0, 1); /* 鼠标悬停时的阴影 */
            transform: translateZ(10px); /* 在 Z 轴上凸起 */
    }
</style>
</html>
相关推荐
IT_陈寒1 天前
SpringBoot自动配置把我都整不会了
前端·人工智能·后端
最逗前端小白鼠1 天前
vue3 数据响应式遇到的问题
前端·vue.js
倚栏听风雨1 天前
ts中 ?? 和 || 区别
前端
冴羽1 天前
请愿书:Node.js 核心代码不应该包含 AI 代码!
前端·javascript·node.js
我家猫叫佩奇1 天前
一款灵感源自《集合啦!动物森友会》的 UI 组件库
前端
mmmmm123421 天前
深入 DOM 查询底层:HTMLCollection 动态原理与 querySelectorAll 静态快照解析
前端·javascript
weixin199701080161 天前
《TikTok 商品详情页前端性能优化实战》
前端·性能优化
闲坐含香咀翠1 天前
告别二次登录!Web端检测并唤起Electron客户端实战
前端·客户端
岁月宁静1 天前
都知道AI大模型能生成文本内容,那你知道大模型是怎样生成文本的吗?
前端·vue.js·人工智能
花间相见1 天前
【终端效率工具01】—— Yazi:Rust 编写的现代化终端文件管理器,告别繁琐操作
前端·ide·git·rust·极限编程