版本说明
当前版本号[20231117]。
版本 | 修改说明 |
---|---|
20231117 | 初版 |
目录
文章目录
移动 Web 第一天
目标:使用位移、缩放、旋转、渐变效果丰富网页元素的呈现方式。
01-平面转换
简介
作用:为元素添加动态效果,一般与过渡配合使用
概念:改变盒子在平面内的形态(位移、旋转、缩放、倾斜)
data:image/s3,"s3://crabby-images/9bfd8/9bfd8206cc1218e923f2874ac2f6c561ba4f224b" alt=""
平面转换也叫 2D 转换 ,属性是 transform
示例
1、首先建个div盒子。
html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>平面转换</title>
<style>
div{
margin: 100px 0;
width: 100px;
height: 100px;
background-color: pink;
}
</style>
</head>
<body>
<div></div>
</body>
</html>
data:image/s3,"s3://crabby-images/1f29a/1f29ab8737740950938b90edc8c0975e9cdd7e37" alt=""
2、设置元素的过渡效果。
css
transition: all 1s;
css
/* 鼠标滑过,来添加动态效果 */
div:hover{
transform: translate(800px);
}
丝滑地滑了过去。
data:image/s3,"s3://crabby-images/50c8d/50c8d79b674afbd12519a0665230ea006207ad2e" alt=""
3、边转边移动。
css
/* 鼠标滑过,来添加动态效果 */
div:hover{
transform: translate(800px) rotate(360deg);
}
data:image/s3,"s3://crabby-images/777e2/777e20cee887f1472586193c359dd6305eb471af" alt=""
4、使图形比之前的大了一圈。
css
/* 鼠标滑过,来添加动态效果 */
div:hover{
transform: translate(800px) rotate(360deg) scale(2);
}
data:image/s3,"s3://crabby-images/5f4ee/5f4ee9521371e5806ec91903dfafbfd31bbf2eda" alt=""
5、鼠标滑过,来添加动态效果。
css
/* 鼠标滑过,来添加动态效果 */
div:hover{
transform: translate(800px) rotate(360deg) scale(2) skew(180deg);
}
data:image/s3,"s3://crabby-images/f89ce/f89ce6d2989ba6351ec2bcc0ac5120b78fa2d4f3" alt=""
平移
css
transform: translate(X轴移动距离, Y轴移动距离);
- 取值
- 像素单位数值
- 百分比(参照盒子自身尺寸计算结果)
- 正负均可
- 技巧
- translate() 只写一个值 ,表示沿着 X 轴移动
- 单独设置 X 或 Y 轴移动距离:translateX() 或 translateY()
定位居中
- 方法一:margin
data:image/s3,"s3://crabby-images/96bb7/96bb733f29224ec526785fc06eb43504c8b66fe2" alt=""
- 方法二:平移 → 百分比参照盒子自身尺寸计算结果
data:image/s3,"s3://crabby-images/a4718/a471827cf0f3a66c4dafac8268fa07d2bb43d992" alt=""
1、建立个box模型。
css
<style>
.box{
width: 200px;
height: 100px;
background-color: pink;
}
</style>
data:image/s3,"s3://crabby-images/7a483/7a483ef8677f776953682d23d674ae71562c9e97" alt=""
2、一个个去尝试。
css
<style>
.box{
position: absolute;
/* 设置边偏移 */
/* 将元素的左边距设置为其父元素的宽度的一半,即水平居中。 */
left: 50%;
/* 将元素的上边距设置为其父元素的高度的一半,即垂直居中。 */
top: 50%;
/* 将元素在水平和垂直方向上分别平移其自身宽度和高度的一半,以实现完全居中的效果。 */
/* 即:往左往上挪字体宽度、高度的一半 */
transform: translate(-50%, -50%);
width: 200px;
height: 100px;
background-color: pink;
}
</style>
data:image/s3,"s3://crabby-images/dc9fe/dc9fea29e60854fb83e7cc4190a7f117806a7e5a" alt=""
案例-双开门
data:image/s3,"s3://crabby-images/70e0c/70e0c8c7dafe61ead2536ae41f36a16b4b4398cc" alt=""
- HTML 结构
html
<div class="father">
<div class="left"></div>
<div class="right"></div>
</div>
- CSS 样式
css
* {
margin: 0;
padding: 0;
}
/* 1. 布局:父子结构,父级是大图,子级是左右小图 */
.father {
display: flex;
margin: 0 auto;
width: 1366px;
height: 600px;
background-image: url(./images/bg.jpg);
overflow: hidden;
}
.father .left,
.father .right {
width: 50%;
height: 600px;
background-image: url(./images/fm.jpg);
transition: all .5s;
}
.father .right {
/* right 表示的取到精灵图右面的图片 */
background-position: right 0;
}
/* 2. 鼠标悬停的效果:左右移动 */
.father:hover .left {
transform: translate(-100%);
}
.father:hover .right {
transform: translateX(100%);
}
1、首先初步建立个模型。
css
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>双开门</title>
<style>
*{
margin: 0;
padding: 0;
}
/* 布局:父子结构,父级是大图,子级是左右小图 */
.father{
margin: 0 auto;
width: 1366px;
height: 600px;
background-image: url(../img/bg.jpg);
}
</style>
</head>
<body>
<div class="father"></div>
</body>
</html>
data:image/s3,"s3://crabby-images/70efd/70efd310a82cd392f10bacc29b6ebc356eacad83" alt=""
2、把左、右两图给设置好。
css
<body>
<div class="father">
<div class="left">1</div>
<div class="right">2</div>
</div>
</body>
css
.father .left,
.father .right{
width: 50%;
height: 600px;
background-image: url(../img/fm.jpg);
}
data:image/s3,"s3://crabby-images/6a4e9/6a4e968ce82e562433c7efcecf91478860ccdc28" alt=""
3、接下来要把右边的精灵图换个位置。
css
.father .right{
background-position: right 0;
}
data:image/s3,"s3://crabby-images/9a82e/9a82e8443ea3a1663b08e3cc4e7f8a6392a1f2d8" alt=""
4、开始移动。
css
/* 鼠标悬停效果:左右移动 */
.father:hover .left{
transform: translate(-100%);
}
.father:hover .right{
transform: translateX(100%);
}
data:image/s3,"s3://crabby-images/d00b1/d00b1c150e3b2ed4a9a39139974c19feed5c7560" alt=""
5、设置慢慢移动。
css
.father .left,
.father .right{
width: 50%;
height: 600px;
background-image: url(../img/fm.jpg);
transition: all 0.5s;
}
6、多余的隐藏起来,实现效果。
css
.father{
display: flex;
margin: 0 auto;
width: 1366px;
height: 600px;
background-image: url(../img/bg.jpg);
overflow: hidden;
}
data:image/s3,"s3://crabby-images/5239b/5239b51b9060487c29292392673a6b7216722c33" alt=""
旋转
css
transform: rotate(旋转角度);
- 取值:角度单位是 deg
- 技巧
- 取值正负均可
- 取值为正 ,顺时针旋转
- 取值为负 ,逆时针旋转
转换原点
默认情况下,转换原点是盒子中心点
css
transform-origin: 水平原点位置 垂直原点位置;
取值:
- 方位名词(left、top、right、bottom、center)
- 像素单位数值
- 百分比
1、首先先做出来一个。
css
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>转换原点</title>
<style>
img{
width: 200px;
border: 1px solid #000;
transition: all 2s;
}
img:hover{
transform: rotate(360deg);
}
</style>
</head>
<body>
<img src="../img/rotate.png" alt="">
</body>
</html>
data:image/s3,"s3://crabby-images/751df/751df3eef6ad326f32382ab555e3803428f5c748" alt=""
2、然后以右下角的原点进行旋转。
css
transform-origin: right bottom;
data:image/s3,"s3://crabby-images/2c05a/2c05a7b0a6b266852a0628850f0c9b87cb443947" alt=""
案例-时钟
先加旋转,当发现旋转没有到位的时候,我们再加transform进行调整
data:image/s3,"s3://crabby-images/9bc0e/9bc0e3a897adec688f0477036c90c076d2ef75aa" alt=""
css样式:
css
.hour {
width: 6px;
height: 50px;
background-color: #333;
margin-left: -3px;
transform: rotate(15deg);
transform-origin: center bottom;
}
.minute {
width: 5px;
height: 65px;
background-color: #333;
margin-left: -3px;
transform: rotate(90deg);
transform-origin: center bottom;
}
.second {
width: 4px;
height: 80px;
background-color: red;
margin-left: -2px;
transform: rotate(240deg);
transform-origin: center bottom;
}
多重转换
多重转换技巧:先平移再旋转
css
transform: translate() rotate();
- 多重转换原理:以第一种转换方式坐标轴为准转换形态
- 旋转会改变网页元素的坐标轴向
- 先写旋转,则后面的转换效果的轴向以旋转后的轴向为准,会影响转换结果
1、先把轮胎与背后的框先画出来。
html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>多重效果</title>
<style>
.box{
width: 800px;
height: 200px;
border: 1px solid #000;
}
img{
width: 200px;
transition: all 5s;
}
</style>
</head>
<body>
<div class="box">
<img src="../img/tyre.png" alt="">
</div>
</body>
</html>
data:image/s3,"s3://crabby-images/f5a2b/f5a2bd28525245423f940842617fe2ac8024a392" alt=""
2、对轮胎进行滚动设置。
css
/* 鼠标滑动,图片开始滚动 */
.box:hover img{
/* 先平移在旋转 */
transform:translate(600px) rotate(360deg);
}
data:image/s3,"s3://crabby-images/5d201/5d201af30ee35689454325ed53577eee73d3f572" alt=""
data:image/s3,"s3://crabby-images/ba0ec/ba0ec2edc9e979afc3cf7a063606980ccf96533f" alt=""
缩放
css
transform: scale(缩放倍数);
transform: scale(X轴缩放倍数, Y轴缩放倍数);
- 技巧
- 通常,只为 scale() 设置一个值,表示 X 轴和 Y 轴等比例缩放
- 取值大于1表示放大,取值小于1表示缩小
如:
css
transform: scale(1); //没有任何效果
transform: scale(2); //放大
transform: scale(0.5); //缩小
案例-播放特效
data:image/s3,"s3://crabby-images/56e99/56e999bffd9516350b81055de83fe48b59335849" alt=""
- CSS 样式
css
/* 1. 摆放播放按钮:图片区域的中间 */
.box li {
overflow: hidden;
}
.pic {
position: relative;
}
.pic::after {
position: absolute;
left: 50%;
top: 50%;
/* margin-left: -29px;
margin-top: -29px; */
/* transform: translate(-50%, -50%); */
content: '';
width: 58px;
height: 58px;
background-image: url(./images/play.png);
transform: translate(-50%, -50%) scale(5);
opacity: 0;
transition: all .5s;
}
/* 2. hover效果:大按钮,看不见:透明是0 → 小按钮,看得见:透明度1 */
.box li:hover .pic::after {
transform: translate(-50%, -50%) scale(1);
opacity: 1;
}
1、建立雏形。
html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>按钮缩放</title>
<style>
* {
margin: 0;
padding: 0;
}
li {
list-style: none;
}
img{
width: 100%;
}
.box{
width: 249px;
height: 210px;
margin: 50px auto;
}
.box p{
color: #3b3b3b;
padding: 10px 10px 0 10px;
}
</style>
</head>
<body>
<div class="box">
<ul>
<li>
<div class="pic">
<img src="../img/party.jpg" alt="">
</div>
<p>【和平精英:"初火"音乐概念片:四圣觉醒......】</p>
</li>
</ul>
</div>
</body>
</html>
data:image/s3,"s3://crabby-images/7fedb/7fedb970d40d430cb1fdb338026dd48508953f5f" alt=""
2、放置播放按钮。
css
.pic{
position: relative;
}
/* 1.摆放播放按钮:图片区域的中间 */
.pic::after{
position: absolute;
content: '';
width: 58px;
height: 58px;
background-image: url(../img/play.png);
}
data:image/s3,"s3://crabby-images/e9fcb/e9fcb0d82aa53a20c03b97a1b343f719c39d4974" alt=""
3、把其放置中间。
css
/* 1.摆放播放按钮:图片区域的中间 */
.pic::after{
position: absolute;
left: 50%;
top: 50%;
margin-left: -29px;
margin-top: -29px;
content: '';
width: 58px;
height: 58px;
background-image: url(../img/play.png);
}
data:image/s3,"s3://crabby-images/3e111/3e111b5276077bc3e253fca98f28ebf16f09a09a" alt=""
4、生成缩放效果。
css
/* 1.摆放播放按钮:图片区域的中间 */
.pic::after{
position: absolute;
left: 50%;
top: 50%;
margin-left: -29px;
margin-top: -29px;
content: '';
width: 58px;
height: 58px;
background-image: url(../img/play.png);
transform: scale(5);
opacity: 0;
transition: all 0.5s;
}
/* 2、hover效果:大按钮,看不见;透明是0 -> 小按钮,看得见;透明度1 */
.box li:hover .pic::after{
transform: scale(1);
opacity: 1;
}
data:image/s3,"s3://crabby-images/729d0/729d05ddb7fdc2e3b00810db5d4e782d1af12e3f" alt=""
5、超出li标签 的部分隐藏一下,就完成了。
css
.box li{
overflow: hidden;
}
注:如果一段css样式中有多条 transform ,就会出现重叠的现象。后面会生效,前面会失效。
解决方法:把所有关于 transform 的语句合在同一句里。
data:image/s3,"s3://crabby-images/12f33/12f33761387b56cffc5b936e926cd33cc985656a" alt=""
倾斜
css
transform: skew();
取值:角度度数 deg
1、transform: skew(30deg);
效果:
css
div:hover{
transform: skew(30deg);
}
data:image/s3,"s3://crabby-images/c8b16/c8b161adac0681dab18eac582b0008737a87ef64" alt=""
2、transform: skew(-30deg);
效果:
css
div:hover{
transform: skew(-30deg);
}
data:image/s3,"s3://crabby-images/2d89d/2d89db4bfb73268a2dfa8f1665e33b32603f2ca4" alt=""
02-渐变
渐变是多个颜色逐渐变化的效果,一般用于设置盒子背景
分类:
- 线性渐变
data:image/s3,"s3://crabby-images/853fa/853fa369fae685d4aca5f7c0eee4e7f801822a94" alt=""
- 径向渐变
data:image/s3,"s3://crabby-images/27eae/27eae154ab9c1b01a0a8b1a6a4cb4202c651b4ea" alt=""
线性渐变
css
background-image: linear-gradient(
渐变方向,
颜色1 终点位置,
颜色2 终点位置,
......
);
取值:
- 渐变方向:可选
- to 方位名词
- 角度度数
- 终点位置:可选
- 百分比
1、从 skyblue 到 yellow 的渐变。
html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>渐变</title>
<style>
div{
width: 200px;
height: 200px;
background-color: skyblue;
background-image: linear-gradient(
skyblue,
yellow
);
}
</style>
</head>
<body>
<div></div>
</body>
</html>
data:image/s3,"s3://crabby-images/56ebc/56ebc373c203c719077a9916f78dc3b4baee0cfc" alt=""
2、从 skyblue 到 yellow ,方向向右的渐变。
css
background-image: linear-gradient(
to right,
skyblue,
yellow
);
data:image/s3,"s3://crabby-images/f23b0/f23b037662ad9790fbfbfd2c8e58680877d0760a" alt=""
3、从 skyblue 到 yellow 的渐变,其中 skyblue 占70%。
css
background-image: linear-gradient(
skyblue 70%,
yellow
);
data:image/s3,"s3://crabby-images/7fdbb/7fdbbd3dfdebe91b7e744821e22e36ed07f6169b" alt=""
案例-产品展示
data:image/s3,"s3://crabby-images/45de3/45de34f5015ee1192fcd944dd7d65a38a88b85da" alt=""
- HTML 结构
html
<div class="box">
<img src="./images/product.jpeg" alt="" />
<div class="title">OceanStor Pacific 海量存储斩获2021 Interop金奖</div>
<div class="mask"></div>
</div>
- CSS 样式
css
.mask {
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 100%;
background-image: linear-gradient(
transparent,
rgba(0,0,0,0.5)
);
opacity: 0;
transition: all .5s;
}
.box:hover .mask {
opacity: 1;
}
径向渐变
给按钮添加高光效果
css
background-image: radial-gradient(
半径 at 圆心位置,
颜色1 终点位置,
颜色2 终点位置,
......
);
取值:
- 半径可以是2条,则为椭圆
- 圆心位置取值:像素单位数值 / 百分比 / 方位名词
1、左、右中心的大小为50px的圆心,从 blue 到 skyblue 的渐变。
css
background-image: radial-gradient(
50px at center center,
blue,
skyblue
);
data:image/s3,"s3://crabby-images/03ad9/03ad96cca8edb9a637f8b45158732c1349508bf8" alt=""
03-综合案例
data:image/s3,"s3://crabby-images/d53a2/d53a22818ad8c21982efd1ba07d8a89b406aa66e" alt=""
导航-频道
箭头旋转
css
.x-header-nav .nav-item:hover .icon-down {
transform: rotate(-180deg);
}
data:image/s3,"s3://crabby-images/33c77/33c77d2a83f92106386fdcbb6ca02d42150da47d" alt=""
频道列表
css
.channel-layer {
position: absolute;
top: 60px;
left: 50%;
z-index: -2;
width: 1080px;
height: 120px;
padding: 10px;
margin-left: -540px;
color: #72727b;
background-color: #f5f5f5;
border: 1px solid #e4e4e4;
border-top: none;
transition: all 0.5s;
transform: translateY(-120px);
}
/* TODO 2. 弹窗频道 */
.x-header-nav .nav-item:hover .channel-layer {
transform: translateY(0);
}
data:image/s3,"s3://crabby-images/b440d/b440dd6e8b26d9a8226ae5e661f8a911d7d5f685" alt=""
渐变按钮
搜索按钮
css
.x-header-search form .btn {
position: absolute;
top: 0;
right: 0;
width: 60px;
height: 40px;
line-height: 40px;
text-align: center;
background-color: #f86442;
border-top-right-radius: 20px;
border-bottom-right-radius: 20px;
background-image: linear-gradient(
to right,
rgba(255, 255, 255, 0.3),
#f86442
);
}
登录按钮
css
/* TODO 7. 渐变按钮 */
.card .card-info .login {
padding: 3px 34px;
color: #fff;
background-color: #ff7251;
border-radius: 30px;
box-shadow: 0 4px 8px 0 rgb(252 88 50 / 50%);
background-image: linear-gradient(
to right,
rgba(255, 255, 255, 0.2),
#ff7251
);
}
客户端按钮
css
/* TODO 8. 径向渐变 */
.download .dl .dl-btn {
width: 68px;
height: 34px;
line-height: 34px;
color: #fff;
text-align: center;
border-radius: 4px;
background-image: radial-gradient(
50px at 10px 10px,
rgba(255, 255, 255, 0.5),
transparent
);
}
轮播图
css
/* TODO 4. 摆放图片 */
.banner .banner-list .banner-item.left {
z-index: 0;
transform: translate(-160px) scale(0.8);
transform-origin: left center;
}
.banner .banner-list .banner-item.right {
z-index: 0;
transform: translate(160px) scale(0.8);
transform-origin: right center;
}
猜你喜欢
css
/* TODO 5. 播放按钮和遮罩 */
.album-item .album-item-box::after {
position: absolute;
left: 0;
top: 0;
content: '';
width: 100%;
height: 100%;
background: rgba(0,0,0,.5) url(../assets/play.png) no-repeat center / 20px;
opacity: 0;
transition: all .5s;
}
.album-item .album-item-box:hover::after {
opacity: 1;
background-size: 50px;
}
/* TODO 6. 图片缩放 */
.album-item .album-item-box:hover img {
transform: scale(1.1);
}