…">
当前位置:首页 > CSS

css制作信封

2026-01-28 08:07:27CSS

使用CSS制作信封效果

通过CSS的边框、阴影和伪元素可以模拟一个信封的展开效果。以下是一个简单的实现方法:

css制作信封

<div class="envelope"></div>
.envelope {
  width: 200px;
  height: 120px;
  background-color: #f9f3e9;
  position: relative;
  border: 1px solid #d4c9b8;
  box-shadow: 0 4px 8px rgba(0,0,0,0.1);
}

.envelope::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  border-bottom: 60px solid #e8d5b5;
  border-left: 100px solid transparent;
  border-right: 100px solid transparent;
  transform-origin: top;
  transform: rotateX(0deg);
  transition: transform 0.5s;
}

.envelope:hover::before {
  transform: rotateX(180deg);
}

信封展开动画

添加悬停动画使信封看起来像被打开:

css制作信封

.envelope {
  perspective: 1000px;
}

.envelope::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 20px;
  background-color: #d4c9b8;
  border-radius: 0 0 5px 5px;
}

添加信纸效果

在信封内创建信纸层:

<div class="envelope">
  <div class="letter"></div>
</div>
.letter {
  position: absolute;
  bottom: 10px;
  left: 10px;
  right: 10px;
  height: 100px;
  background-color: white;
  box-shadow: 0 1px 3px rgba(0,0,0,0.1);
  transition: all 0.3s;
}

.envelope:hover .letter {
  transform: translateY(-40px);
  height: 140px;
}

完整信封样式

结合所有元素创建更真实的效果:

.envelope {
  width: 220px;
  height: 150px;
  background: #f5e7d0;
  border-radius: 5px;
  position: relative;
  box-shadow: 0 3px 10px rgba(0,0,0,0.2);
  margin: 50px auto;
  cursor: pointer;
}

.envelope::before {
  content: '';
  position: absolute;
  top: 0;
  width: 0;
  height: 0;
  border-left: 110px solid transparent;
  border-right: 110px solid transparent;
  border-top: 75px solid #e8cfa6;
  transform-origin: top;
  z-index: 2;
  transition: all 0.3s ease-in-out;
  transform: rotateX(0deg);
}

.envelope:hover::before {
  transform: rotateX(180deg);
}

.letter {
  position: absolute;
  bottom: 10px;
  left: 20px;
  right: 20px;
  height: 120px;
  background: white;
  transition: all 0.3s ease-in-out;
  box-shadow: 0 0 5px rgba(0,0,0,0.1);
  padding: 10px;
  box-sizing: border-box;
}

.envelope:hover .letter {
  transform: translateY(-50px);
  height: 170px;
}

这些CSS技巧可以组合使用来创建各种信封效果,通过调整颜色、尺寸和动画参数可获得不同的视觉效果。

标签: 信封css
分享给朋友:

相关文章

css网页制作教程

css网页制作教程

CSS网页制作教程 CSS(层叠样式表)是用于控制网页外观和布局的核心技术。以下是CSS网页制作的关键步骤和技巧: 基础语法与引入方式 CSS规则由选择器和声明块组成: 选择器 { 属性:…

css 导航栏制作

css 导航栏制作

水平导航栏制作 使用无序列表<ul>和<li>标签构建基础结构,通过CSS将列表项横向排列 <nav> <ul class="horizontal-na…

css样式表制作

css样式表制作

CSS样式表制作基础 CSS(层叠样式表)用于控制网页的视觉呈现。通过CSS可以定义字体、颜色、布局等样式属性。 内联样式 直接在HTML标签中使用style属性定义样式: <p sty…

css div 制作导航菜单

css div 制作导航菜单

基本导航菜单结构 使用HTML创建一个简单的导航菜单结构,通常使用<ul>和li>列表实现。每个菜单项用<a>标签包裹以实现链接功能。 <div class="…

css二级菜单制作

css二级菜单制作

使用纯CSS实现二级菜单 通过嵌套HTML结构和CSS选择器实现二级菜单的显示与隐藏效果。以下是一个基础实现方案: HTML结构: <ul class="menu"> <li…

css制作登录界面

css制作登录界面

使用CSS制作登录界面 登录界面是网站常见的功能模块,通过CSS可以实现美观且响应式的设计。以下是一个基础的登录界面实现方法。 HTML结构 基础的HTML结构包含表单元素,如输入框、按钮和标签。…