Web进阶:Day1 字体图标、平面转换、空间转换、动画

简介: Web进阶:Day1 字体图标、平面转换、空间转换、动画

Web进阶:Day1

Date: October 3, 2022

Summary: 字体图标、平面转换、空间转换、动画


字体图标

字体图标


字体图标展示的是图标,本质是字体


处理简单的、颜色单一的图片


注:复杂的用CSS精灵,简单的用字体图标


字体图标的优点:


灵活性:灵活地修改样式,例如:尺寸、颜色等


轻量级:体积小、渲染快、降低服务器请求次数


兼容性:几乎兼容所有主流浏览器


使用方便:


1.下载字体包

2.使用字体图标


图标库


Iconfont:https://www.iconfont.cn/

29cab1dd0ccc965068edf0a4f0484c6e.png

c917848c882468f0a43332fff4ccd934.png


具体步骤:

使用字体图标 - Unicode编码:


1.引入样式表:iconfont.css

2.复制粘贴图标对应的Unicode编码

<span>&#xe6f8;</span>

1.设置文字字体

span{
  font-family:'iconfont';
}

使用字体图标 – 类名:


1.引入字体图标样式表

<link rel="stylesheet" href="./iconfont.css">

1.调用图标对应的类名,必须调用2个类名

  1.iconfont类:基本样式,包含字体的使用等

  2.icon-xxx:图标对应的类名

<span class="iconfont icon-xxx"></span>

案例:基础练习


Code:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <link rel="stylesheet" href="./iconfont/iconfont.css">
    <style>
        i{
            font-size: 60px;
        }
    </style>
</head>
<body>
    <!-- iconfont是固定的  icon-favorites-fill是你要的图标-->
    <i class="iconfont icon-favorites-fill"></i>
</body>
</html>

案例:淘宝


Code :

<head>
    <!-- 
        练习:
            1.引样式表
            2.调用类名
     -->
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>购物车</title>
    <!-- 引样式表 -->
    <link rel="stylesheet" href="./iconfont/iconfont.css">
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        li {
            list-style: none;
        }
        a {
            color: #333;
            text-decoration: none;
        }
        .nav {
            width: 200px;
            margin: 50px auto;
            font-size: 12px;
        }
        /* 让图标变橙 */
        .orange {
            color: #f40;
        }
    </style>
</head>
<body>
    <div class="nav">
        <ul>
            <li>
                <a href="#">
                ddd    <!-- 调用类名 -->
                    <span class="iconfont icon-cart-Empty-fill orange"></span>
                    <span>购物车</span>
                    <span class="iconfont icon-arrow-down"></span>
                </a>
            </li>
        </ul>
    </div>
</body>

上传矢量图:


思考:如果图标库没有项目所需的图标怎么办?


答:IconFont网站上传矢量图生成字体图标


1.与设计师沟通,得到SVG矢量图


2.IconFont网站上传图标,下载使用


上传矢量图:


上传 → 上传SVG图标


浏览本地图标 → 去除颜色提交


加入购物车 → 下载使用

eccffb0fe0c9ec0682c7cf0b55bd6511.png


平面转换

平面转换基础:

平面转换概念


改变盒子在平面内的形态(位移、旋转、缩放),这是一种2D转换


平面转换属性

f76d6105b840e4d0bb577af506e351fb.png

语法

transform: translate(水平移动距离, 垂直移动距离);

取值(正负均可)


像素单位数值


百分比(参照物为盒子自身尺寸)


注意:X轴正向为右,Y轴正向为下


eg:

transform: translate(100px, 100px);
/* 百分比: 盒子自身尺寸的百分比 */
/* transform: translate(100%, 50%); */
/* 只给出一个值表示x轴移动距离 */
/* transform: translate(100px); */
/* transform: translateY(100px); */

补充技巧:


translate()如果只给出一个值, 表示x轴方向移动距离


单独设置某个方向的移动距离:translateX() & translateY()


案例:


使用translate快速实现绝对定位的元素居中效果

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>绝对定位元素居中效果</title>
    <style>
        .father {
            position: relative;
            width: 500px;
            height: 300px;
            margin: 100px auto;
            border: 1px solid #000;
        }
        .son {
            position: absolute;
            left: 50%;
            top: 50%;
            /* margin-left: -100px;
            margin-top: -50px; */
            transform: translate(-50%, -50%);
            width: 203px;
            height: 100px;
            background-color: pink;          
        }
    </style>
</head>
<body>
    <div class="father">
        <div class="son"></div>
    </div>
</body>
</html>

理解:

72552549e8f6fe011fb469ad20e48b21.png

这是初始位置:

left: 50%;
top: 50%;

经过位移转变后:

transform: translate(-50%, -50%);

双开门:

原理:位移取值为百分比数值,参照盒子自身尺寸计算移动距离


右侧盒子背景图


left:向左侧移动自身宽度


right:向右侧移动自身宽度


案例:玛莎拉蒂

e6355cc75f2546748c7b78dce94d9704.png

Code:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        .box {
            width: 1366px;
            height: 600px;
            margin: 0 auto;
            background: url('./images/bg.jpg');
            /* 超出父级范围的要隐藏 */
            overflow: hidden;
        }
        .box::before,
        .box::after {
            float: left;
            content: '';
            width: 50%;
            height: 600px;
            background-image: url(./images/fm.jpg);
            transition: all .5s;
        }
        .box::after {
            background-position: right 0;
        }
        /* 鼠标移入的时候的位置改变的效果 */
        .box:hover::before {
            transform: translate(-100%);
        }
        .box:hover::after {
            transform: translateX(100%);
        }
    </style>
</head>
<body>
    <div class="box">
    </div>
</body>
</html>

旋转

语法


transform: rotate(角度);


注意:角度单位是deg


技巧:取值正负均可


取值为正, 则顺时针旋转


取值为负, 则逆时针旋转


Code:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>旋转效果</title>
    <style>
        img {
            width: 250px;
            /* 需要保证有时间过渡,否则将会无法运转 */
            transition: all 2s;
        }
        img:hover {
            /* 顺 */
            transform: rotate(360deg);
            /* 逆 */
            /* transform: rotate(-360deg); */
        }
    </style>
</head>
<body>
    <img src="./images/rotate.png" alt="">
</body>
</html>

转换原点

cacff54471f14464bca11f0e6af62773.png

语法

transform-origin: 原点水平位置 原点垂直位置;

注意 : 默认圆点是盒子中心点


取值


方位名词(left、top、right、bottom、center)


这个是基于哪个点进行旋转,重点常用,下面不常用


像素单位数值


百分比(参照盒子自身尺寸计算)


案例:

21fc757b7c55c3e5757ada02e8fb6583.png

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>转换原点</title>
    <style>
        img {
            width: 250px;
            border: 1px solid #000;
            transition: all 2s;
            transform-origin: right bottom;
            transform-origin: left bottom;
        }
        img:hover {
            transform: rotate(360deg);
        }
    </style>
</head>
<body>
    <img src="./images/rotate.png" alt="">
</body>
</html>

多重转换

9f4962042b5ee4151b587aa92f3306d1.png

多重转换代码:

transform: translate() rotate();

案例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>多重转换</title>
    <style>
        .box {
            width: 800px;
            height: 200px;
            border: 1px solid #000;
        }
        img {
            width: 200px;
            transition: all 8s;
        }
        .box:hover img {
            /* 边走边转 */
            transform: translate(600px) rotate(360deg);
            /* 旋转可以改变坐标轴向 */
            /* transform: rotate(360deg) translate(600px); */
            /* 层叠性 */
            /* transform: translate(600px);
            transform: rotate(360deg); */
        }
    </style>
</head>
<body>
    <div class="box">
        <img src="./images/tyre1.png" alt="">
    </div>
</body>
</html>

多重转换原理


旋转会改变网页元素的坐标轴向

先写旋转,则后面的转换效果的轴向以旋转后的轴向为准,会影响转换结果


所以我们先以translate为基准,在保证坐标轴向的基础上,进一步地让轮胎旋转


缩放

思考: 改变元素的width或height属性能实现吗?


**语法:**transform: scale(x轴缩放倍数, y轴缩放倍数);


技巧


一般情况下, 只为scale设置一个值, 表示x轴和y轴等比例缩放


transform: scale(缩放倍数);


scale值大于1表示放大, scale值小于1表示缩小


案例:

60ac86d8c302b751181de04fdae1d04b.png

Code:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>缩放效果</title>
    <style>
        .box {
            width: 300px;
            height: 210px;
            margin: 100px auto;
            background-color: pink;
        }
        .box img {
            width: 100%;
            transition: all 0.5s;
        }
        .box:hover img {
            /* width: 150%; */
            transform: scale(1.2);
            transform: scale(0.8);
        }
    </style>
</head>
<body>
    <div class="box">
        <img src="./images/product.jpeg" alt="">
    </div>
</body>
</html>

案例:和平精英

ec419dfbfeab30683b6d97e1f96df7d6.png

播放按钮


布局 ::after


样式 居中


效果


缩放


透明度(opacity)


Code:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        li {
            list-style: none;
        }
        img {
            width: 100%;
        }
        .box {
            width: 249px;
            height: 210px;
            margin: 50px auto;
            overflow: hidden;
        }
        .box p {
            color: #3b3b3b;
            padding: 10px 10px 0 10px;
        }
        .box .pic {
            position: relative;
        }
        .box .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;
        }
        /* lihover的时候,  谁变小pic::after */
        .box li:hover .pic::after {
            opacity: 1;
            transform: translate(-50%, -50%) scale(1);
        }
    </style>
</head>
<body>
    <div class="box">
        <ul>
            <li>
                <div class="pic"><img src="./images/party.jpeg" alt=""></div>
                <p>【和平精英】“初火”音乐概念片:四圣觉醒......</p>
            </li>
        </ul>
    </div>
</body>
</html>

渐变

渐变是多个颜色逐渐变化的视觉效果


一般用于设置盒子的背景


方式1:

background-image: linear-gradient(
    颜色1,
    颜色2
);

方式2:

background-image: linear-gradient(
    transparent,
    rgba(0,0,0, .6)
);

案例:

df6a2958b4345f2e3416e83011ca61e2.png

Code:

<!DOCTYPE html>
  <html lang="en">
  <head>
      <meta charset="UTF-8">
      <meta http-equiv="X-UA-Compatible" content="IE=edge">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <title>Document</title>
      <style>
          .box{
              width: 300px;
              height: 200px;
              background-image: linear-gradient(
                  transparent,
                  rgba(0,0,0, .6)
              );
          }
      </style>
  </head>
  <body>
      <div class="box"></div>
  </body>
  </html>

案例:华为渐变产品

1a229eb792dd88f5d5b2f17303c7fa4a.png

Code:

<!DOCTYPE html>
  <html lang="en">
  <head>
      <meta charset="UTF-8">
      <meta http-equiv="X-UA-Compatible" content="IE=edge">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <title>Document</title>
      <style>
          .box {
              position: relative;
          }
          .box img {
              width: 300px;
          }
          .box .title {
              position: absolute;
              left: 15px;
              bottom: 20px;
              /* 放在顶层 */
              z-index: 2;
              width: 260px;
              color: #fff;
              /* 字体大小 */
              font-size: 20px;
              /* 字体粗细 */
              font-weight: 700;
          }
          .box .mask {
              position: absolute;
              left: 0;
              top: 0;
              opacity: 0;
              width: 300px;
              height: 212px;
              background-image: linear-gradient(
                  transparent,
                  rgba(0, 0, 0, .6)
              );
              transition: all .5s;
          }
          .box:hover .mask {
              opacity: 1;
          }
      </style>
  </head>
  <body>
      <div class="box">
          <img src="./images/product.jpeg" alt="?">
          <div class="title">OceanStor Pacific 海量存储斩获2021 Interop金奖</div>
          <div class="mask"></div>
      </div>
  </body>
  </html>

综合案例:

案例;

ea43e16d544b37da6e846df0a2971d47.png

Code: HTML

<!DOCTYPE html>
  <html lang="en">
  <head>
      <meta charset="UTF-8">
      <meta http-equiv="X-UA-Compatible" content="IE=edge">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <title>华为新闻</title>
      <link rel="stylesheet" href="./iconfont/iconfont.css">
      <link rel="stylesheet" href="./css/demo.css">
  </head>
  <body>
      <div class="box">
          <ul>
              <li>
                  <a href="#">
                      <div class="pic">
                          <img src="./images/product.jpeg" alt="">
                      </div>
                      <div class="txt">
                          <h4>产品</h4>
                          <h5>OceanStor Pacific 海量存储斩获2021 Interop金奖</h5>
                          <p>
                              <span>了解更多</span>
                              <i class="iconfont icon-arrow-right"></i>
                          </p>
                      </div>
                      <!-- 添加渐变背景 -->
                      <div class="mask"></div>
                  </a>
              </li>
              <li>
                  <a href="#">
                      <div class="pic">
                          <img src="./images/huawei1.jpeg" alt="">
                      </div>
                      <div class="txt">
                          <h4>行业洞察</h4>
                          <h5>迈向智能世界2030</h5>
                          <p>
                              <span>了解更多</span>
                              <i class="iconfont icon-arrow-right"></i>
                          </p>
                      </div>
                      <!-- 添加渐变背景 -->
                      <div class="mask"></div>
                  </a>
              </li>
              <li>
                  <a href="#">
                      <div class="pic">
                          <img src="./images/huawei2.jpeg" alt="">
                      </div>
                      <div class="txt">
                          <h4>《ICT新视界》刊首语</h4>
                          <h5>笃行致远,共建具有获得感、幸福感、安全感的智慧城市</h5>
                          <p>
                              <span>了解更多</span>
                              <i class="iconfont icon-arrow-right"></i>
                          </p>
                      </div>
                      <!-- 添加渐变背景 -->
                      <div class="mask"></div>
                  </a>
              </li>
          </ul>
      </div>
  </body>
  </html>

Code:CSS

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
li {
    list-style: none;
}
a {
    text-decoration: none;
}
img {
    width: 100%;
    vertical-align: middle;
}
.box {
    width: 1110px;
    height: 247px;
    margin: 20px auto;
    /* background-color: pink; */
}
.box li {
    position: relative;
    float: left;
    width: 350px;
    height: 247px;
    margin-right: 30px;
    /* 溢出隐藏 */
    overflow: hidden;
}
.box li:last-child {
    margin-right: 0;
}
.box .txt {
    position: absolute;
    left: 0;
    bottom: -50px;
    width: 350px;
    height: auto;
    padding: 20px 30px;
    z-index: 1;
    color: #fff;
    transition: transform .5s;
    /* transition: all .5s; */
}
.box .txt h4 {
    font-size: 14px;
    font-weight: 400;
    line-height: 2em;
    color: #fff;
}
.box .txt h5 {
    margin-bottom: 40px;
    font-size: 18px;
    line-height: 1.5em;
    color: #fff;
}
.box .txt p {
    color: #fff;
    font-size: 14px;
}
.box .txt p .iconfont {
    color: #c7000b;
    vertical-align: middle;
    font-size: 20px;
    font-weight: 700;
}
/* 1. 渐变背景的盒子 */
.box .mask {
    position: absolute;
    left: 0;
    top: 0;
    width: 350px;
    height: 247px;
    background-image: linear-gradient(
        transparent,
        rgba(0,0,0,.6)
    );
    opacity: 0;
    transition: all .5s;
}
/* 2. hover效果 */
/* 2.1 图片缩放 */
.box li .pic img {
    transition: all .5s;
}
.box li:hover .pic img {
    transform: scale(1.2);
}
/* 2.2 渐变背景显示 */
.box li:hover .mask {
    opacity: 1;
}
/* 2.3 文字向上移动 */
.box li:hover .txt {
    transform: translateY(-50px);
}
相关文章
|
6月前
|
网络协议 小程序 生物认证
Web应用&企业产权&指纹识别&域名资产&网络空间&威胁情报
Web应用&企业产权&指纹识别&域名资产&网络空间&威胁情报
|
4月前
|
前端开发
HTML+CSS动画实现动感3D卡片墙:现代Web设计的视觉盛宴
HTML+CSS动画实现动感3D卡片墙:现代Web设计的视觉盛宴
|
5月前
|
SQL 安全 Go
SQL注入不可怕,XSS也不难防!Python Web安全进阶教程,让你安心做开发!
【7月更文挑战第26天】在 Web 开发中, SQL 注入与 XSS 攻击常令人担忧, 但掌握正确防御策略可化解风险. 对抗 SQL 注入的核心是避免直接拼接用户输入至 SQL 语句. 使用 Python 的参数化查询 (如 sqlite3 库) 和 ORM 框架 (如 Django, SQLAlchemy) 可有效防范. 防范 XSS 攻击需严格过滤及转义用户输入. 利用 Django 模板引擎自动转义功能, 或手动转义及设置内容安全策略 (CSP) 来增强防护. 掌握这些技巧, 让你在 Python Web 开发中更加安心. 安全是个持续学习的过程, 不断提升才能有效保护应用.
59 1
|
5月前
|
缓存 JavaScript 前端开发
JavaScript进阶 - Web Workers与Service Worker
【7月更文挑战第4天】JavaScript的Web Workers和Service Worker增强了Web性能。Web Workers处理后台多线程,减轻主线程负担,但通信有开销,受同源策略限制。Service Worker则用于离线缓存和推送通知,需管理其生命周期、更新策略,并确保安全。两者都带来了挑战,但也极大提升了用户体验。通过理解和优化,开发者能构建更高效、安全的Web应用。
146 2
|
5月前
|
前端开发 开发者 Python
从零到一:Python Web框架中的模板引擎入门与进阶
【7月更文挑战第20天】模板引擎如Jinja2在Python Web开发中连接后端与前端,提高代码可读性和协作效率。Flask默认集成Jinja2,提供条件语句、循环、宏和模板继承等功能。例如,创建一个简单Flask应用,渲染&quot;Hello, World!&quot;,并展示如何使用条件语句和循环处理数据。通过宏定义重用代码,模板继承实现页面结构共享。学习模板引擎能提升开发效率和项目质量。
69 0
|
5月前
|
SQL 前端开发 数据库
Python Web开发进阶之路:从模板引擎到ORM的全面掌握
【7月更文挑战第19天】在Python Web开发中,提升技能的关键是理解和运用模板引擎(如Jinja2)与ORM技术。模板引擎,如在Flask中使用的Jinja2,使前端HTML与后端逻辑分离,便于维护。例如,通过路由函数`show_posts()`和`render_template()`呈现文章列表模板,用Jinja2的`for`循环展示内容。ORM,如SQLAlchemy,提供Pythonic的数据库操作,将表映射为类,SQL转化为方法调用。在博客系统中,定义Post模型并与数据库交互,展示了ORM简化数据管理的优势。通过实践这些工具,开发者能更好地驾驭复杂的Web项目。
60 0
|
6月前
|
JavaScript 前端开发 UED
在Web开发中,拖放(Drag and Drop)和动画效果是提升用户体验的重要工具
【6月更文挑战第12天】本文介绍了如何使用JavaScript实现拖放功能和基本动画效果。拖放功能通过监听mousedown、mousemove和mouseup事件,计算并更新元素位置实现。动画效果则利用requestAnimationFrame函数创建平滑移动的视觉效果。示例代码包括HTML结构和对应的JavaScript实现。
80 1
|
5月前
|
缓存 前端开发 JavaScript
JavaScript进阶 - Web Workers与Service Worker
【7月更文挑战第10天】在Web开发中,Web Workers和Service Worker提升性能。Workers运行后台任务,防止界面冻结。Web Workers处理计算密集型任务,Service Worker则缓存资源实现离线支持。常见问题包括通信故障、资源限制、注册错误及缓存更新。通过示例代码展示了两者用法,并强调生命周期管理和错误处理的重要性。善用这些技术,可构建高性能的Web应用。
119 0
|
5月前
|
缓存 JavaScript 前端开发
JavaScript进阶 - Web Workers与Service Worker
【7月更文挑战第6天】JavaScript的Web Workers和Service Worker增强了浏览器的性能处理和离线功能。Web Workers处理后台计算,减轻主线程压力,但通信有开销,受同源策略限制。Service Worker则能拦截网络请求,支持离线缓存和推送通知,但其生命周期和权限管理需谨慎处理。通过理解它们的工作原理和限制,开发者能创建更流畅、更健壮的Web应用。
121 0
|
6月前
|
资源调度 前端开发 JavaScript
web实现酷炫的canvas粒子动画背景
web实现酷炫的canvas粒子动画背景
143 0