首页 > 其他分享 >移动web

移动web

时间:2024-04-11 12:29:58浏览次数:23  
标签:web 动画 less transform animation rem 移动 取值

01-平面转换

作用:为元素添加动态效果,一般与过渡配合使用 概念:改变盒子在平面内的形态,平面转换又叫2D转换

平移

属性:transform: translate(X轴移动距离, Y轴移动距离);

取值

(1)像素单位数值

(2)百分比

(3)正负均可

技巧

translate() ,表示沿着 x轴移动

单独设置 X 或 Y 轴移动距离:translateX() 或 translateY()

绝对定位实现元素居中效果

法一:

div {
            position: absolute;
            background-color: aqua;
            height: 100px;
            width: 200px;
            left: 50%;
            bottom: 50%;
            margin-left: -100px;
            margin-bottom: -50px;
        }

法二:

position: absolute;
left: 50%;
top: 50%;
transform: translate(-50%,-50%);

旋转

属性:transform

取值:角度单位是 deg

注意:

取值正负均可

取值为正,顺时针旋转

取值为负,逆时针旋转

改变转换原点

默认情况下,转换原点是盒子中心点

属性:transform-origin

取值:

(1)方位名词

(2)像素单位数值

(3)百分比

多重转换

技巧:先平移再旋转

属性:transform: translate() rotate();

原理:以第一种转换方式坐标轴为准转换形态

缩放

属性:transform: scale();

技巧:

(1)通常,只为 scale() 设置一个值,表示 X 轴和 Y 轴等比例缩放

(2)取值大于1表示放大,取值小于1表示缩小

倾斜

属性:transform: skew();

取值:角度

渐变

渐变是多个颜色逐渐变化的效果,一般用于设置盒子背景

分类:线性渐变和径向渐变

线性渐变

background-image: linear-gradient(
  渐变方向,
  颜色1 终点位置,
  颜色2 终点位置,
  ......
);

取值:

渐变方向:可选

  • to 方位名词

  • 角度度数

终点位置:可选

综合案例:

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .mask {
            position: absolute;
            left: 0;
            top: 0;
            width: 100%;
            height: 100%;
            background-image: linear-gradient(transparent,
                    rgba(0, 0, 0, .5));
            opacity: 0;
            transition: all .5s;
        }
​
        .box:hover .mask {
            opacity: 1;
        }
​
        .box {
            position: relative;
            height: 300px;
            width: 300px;
            margin: auto;
            background-color: aquamarine;
            background-image: url(../images/微信图片_20230906220156.jpg);
            background-size: 100%;
        }
​
​
        .box .title {
            position: absolute;
            bottom: 10%;
            left: 30%;
            z-index: 4;
            color: #fff;
            font-size: 30px;
        }
    </style>
</head>
​
<body>
    <div class="box">
        <div class="title">你好啊!</div>
        <div class="mask"></div>
    </div>
</body>

 

5e51b287a1c68ec2ce1929a0d8ac7d5d.png

径向渐变

background-image: radial-gradient(
  半径 at 圆心位置,
  颜色1 终点位置,
  颜色2 终点位置,
  ......
);

取值:

  • 半径可以是2条,则为椭圆

  • 圆心位置取值:像素单位数值 / 百分比 / 方位名词

空间转换

平移

transform: translate3d(x, y, z);
transform: translateX();
transform: translateY();
transform: translateZ();

取值与平面转换相同

默认情况下,Z 轴平移没有效果

原因:电脑屏幕默认是平面,无法展示z轴效果

视距

作用:指定了观察者与 Z=0 平面的距离,为元素添加透视效果

透视效果:近大远小、近实远虚

属性:添加给父级,取值范围 800-1200

perspective:视距;

旋转

x轴:rotateX() y轴:rotateY() z轴:rotateZ() rotate3d(x, y, z) :用来设置自定义旋转轴的位置及旋转的角度

左手法则:左手握住旋转轴, 拇指指向正值方向, 其他四个手指弯曲方向为旋转正值方向

(用来判断方向)

立体呈现

作用:设置元素的子元素是位于 3D 空间中还是平面中

属性名:transform-style

属性值:

  • flat:子级处于平面中

  • preserve-3d:子级处于 3D 空间

步骤:

(1)搭建立方体

(2)鼠标悬停,立方体旋转

综合案例:3d导航

<style>
        .box {
            height: 30px;
            width: 100px;
            position: relative;
            margin: auto;
            transition: all .5s;
            text-align: center;
            line-height: 30px;
            transform-style: preserve-3d;
        }
​
        .box .font {
            position: absolute;
            left: 0;
            bottom: 0;
            height: 100%;
            width: 100%;
            background-color: antiquewhite;
            transform: translateZ(15px);
        }
​
        .box .last {
            background-color: lightcyan;
            transform: translateZ(15px) rotateX(90deg);
        }
​
        .box:hover {
            transform: rotateX(-90deg);
        }
    </style>
</head>
​
<body>
    <div class="box">
        <div class="font">首页</div>
        <div class="last">index</div>
    </div>
</body>

缩放

transform: scale3d(x, y, z);
transform: scaleX();
transform: scaleY();
transform: scaleZ();

02- 动画

动画实现步骤

1、定义动画

/* 方式一 */
@keyframes 动画名称 {
  from {}
  to {}
}
​
/* 方式二 */
@keyframes 动画名称 {
  0% {}
  10% {}
  ......
  100% {}
}

2、使用动画

animation: 动画名称 动画花费时长;

animation复合属性

animation:动画名称 动画时长 速度曲线 延迟时间 重复次数 动画方向 执行完毕时状态

提示:

  • 动画名称和动画时长必须赋值

  • 取值不分先后顺序

  • 如果有两个时间值,第一个时间表示动画时长,第二个时间表示延迟时间

属性作用取值
animation-name动画名称 
animation-duration动画时长 
animation-delay延迟时间 
animation-fill-mode动画执行完毕时状态forwards backwards
animation-timing-function速度曲线steps(数字):逐帧动画
animation-iteration-count重复次数infinite为无限循环
animation-direction动画执行方向alternate为反向
animation-play-state暂停动画paused为暂停,通常配合:hover使用

精灵动画

核心:

属性作用取值
animation-timing-function速度曲线steps(数字):逐帧动画

制作步骤

1.准备显示区域

盒子尺寸与一张精灵小图尺寸相同

2.定义动画

移动背景图(移动距离 = 精灵图宽度)

3.使用动画

steps(N),N 与精灵小图个数相同

多组动画

animation: 
  动画一,
  动画二,
  ... ...
;

03-rem适配

一般逻辑分辨率与物理分辨率不同

记住:375*667

二倍图:防止在高分辨率屏幕下失真(每个元素的尺寸的倍数)

(一般375宽度的设计稿是750px

rem

  • rem单位,是相对单位

  • rem单位是相对于HTML标签的字号计算结果

  • 1rem = 1HTML字号大小

媒体查询

@media (媒体特性) {
  选择器 {
    css属性
  }
}

使用案例:

 

225efefdd322e80d647a3ac06da5062f.png

目前rem布局方案中,将网页等分成10份, HTML标签的字号为视口宽度的 1/10

flexible.js

flexible.js 是手淘开发出的一个用来适配移动端的 js 库。

核心原理就是根据不同的视口宽度给网页中 html 根节点设置不同的 font-size。

(一般开发中不用自己写)

rem 移动适配

rem单位尺寸

1.确定基准根字号

查看设计稿宽度 → 确定参考设备宽度(视口宽度) → 确定基准根字号(1/10视口宽度)

2.rem单位的尺寸

rem单位的尺寸 = px单位数值 / 基准根字号

less

运算

  • 加、减、乘直接书写计算表达式

  • 除法需要添加小括号 (单位直接写在后面)

less-嵌套

作用:快速生成后代选择器

 

312b00fe583f77661ac2f71bed57af9f.png

注意:用 & 表示当前选择器,不会生成后代选择器,通常配合伪类或伪元素使用

less-变量

概念:容器,存储数据

作用:存储数据,方便使用和修改

语法:

(1)定义变量:@变量名: 数据;

(2)使用变量:CSS属性:@变量名;

 

5a13b8c5bbca5455071ebe1891fc384c.png

less-导入

作用:导入 less 公共样式文件

语法:导入: @import “文件路径”;

提示:如果是 less 文件可以省略后缀

@import './base.less';
@import './common';

less-导出

写法:在 less 文件的第一行添加 // out: 存储URL

提示:文件夹名称后面添加 /

// out: ./index.css
// out: ./css/

less-禁止导出

写法:在 less 文件第一行添加: // out: false

04-vw适配方案

适配方案

  • 相对单位

  • 相对视口尺寸计算结果

  • vw:viewport width ( 1vw = 1/100视口高度 )

  • vh:viewport height ( 1vh = 1/100视口高度 )

vw布局

1.确定设计稿对应的vw尺寸

2.vw单位尺寸=px单位数据/(1/100视口宽度)

vh布局

1.确定设计稿对应的vh尺寸

2.vh单位尺寸=px单位数据/(1/100视口高度)

注意

在实际开发中,不要将vhvw混用

 

标签:web,动画,less,transform,animation,rem,移动,取值
From: https://blog.csdn.net/2301_80466038/article/details/137634170

相关文章

  • ssm基于spring和vue开发的web新闻流媒体平台论文
    摘要如今的时代,是有史以来最好的时代,随着计算机的发展到现在的移动终端的发展,国内目前信息技术已经在世界上遥遥领先,让人们感觉到处于信息大爆炸的社会。信息时代的信息处理肯定不能用之前的手工处理这样的解决方法,必须采用计算机来处理这些信息,因为传统方法对应计算机处......
  • Centos7-kvm-WEB管理工具kimchi使用篇
    镜像上传接上篇安装完wok和kimchi这两个服务后,能正常访问https://localhost:8001 (输入地址一定是Https!!!)   功能介绍导航栏wok是查看报错日志和操作记录的,同时设置项可以开关kimchi状态     导航栏的Virtualization分为访客模板存储器网络(这......
  • [Web逆向] 一个在线php加密文件的解密【转载】
    转自:https://www.52pojie.cn/thread-1912173-1-1.html免费加密网站:aHR0cDovL2RlcGhwLm5ldC9lbmNyeXB0Lmh0bWw=加密前代码:[PHP]纯文本查看复制代码<?php  echo"请破我!"?><?php  echo"<br/>我爱破姐!"?>运行如下:image.png(13.92KB,下载次数:......
  • 自动化运维(十五)Ansible 实战之批量创建WEB服务器
        前面我们学习了一些Ansible模块的知识,从这一块篇开始我们进入到 Ansible实战内容的学习,我们会根据实际应用中的一些案例来演示这些模块的综合应用。现在我们有这么一个需求:在esxi虚拟机192.168.110.2上创建5台web服务器,web服务器配置为2核4G,50G硬盘,安装nginx服务......
  • javaweb项目没有main方法?
    在写javaweb项目中忽然发现没有main方法的,没有入口怎么跑?其实项目是有main方法的,不需要我们编写代码,main方法在tomcat容器中。tomcat是运行在虚拟机之上的。Junit是有主函数的,就在junit框架源码里面。从main开始执行,反射运行各个testcase,然后结束。在一个基于JavaW......
  • Spring Maven项目添加web模块
    问题描述:IDEA新建的maven项目没有web模块,如何新增web模块?操作步骤:1、选中对应的模块名称,右键单击“OpenModuleSettings” 2、如果模块下②web存在,则按照图一步骤顺序,依次选择“+”,在Type单击web.xml,path路径为默认路径,如果想要修改,可以单击步骤⑤修改,否则,执行步骤⑥和⑦......
  • 创建一个简单的区块链,并使用 Flask 框架提供一个简单的 Web 接口来与区块链交互。
    目录前言一、代码展示二、代码注释1.简单的区块链模拟实现,这段代码定义了一个简单的区块链类,可以创建一个新的区块链,并能够添加新的区块到链上,同时获取最新的区块信息。这个模拟的区块链可以用于教学或演示区块链的基本概念。2.这段代码是一个简单的工作量证明(ProofofWo......
  • 后端开发之SpringBootWeb入门介绍及简单测试 2024详解
    SpringBoot介绍官网spring.ioSpring是最流行的Java框架Spring发展到今天已经形成了一种开发生态圈Spring提供了若干个子项目每个项目用于完成特定的功能企业开发框架之间的整合会很容易所以我们选择Spring全家桶基于基础的SpringFramework框架但是配置繁琐入门......
  • CTFshow-Web入门模块-爆破
    CTFshow-Web入门模块-爆破by故人叹、web21考察点:burpsuite使用、自定义迭代器使用题目提供了字典,要求登录并提示了爆破,使用burpsuite抓包并操作:(1)用户名一般为admin,密码随意输,抓包并发送给爆破模块。可以看到Basic后有一段base64编码,解码得到用户名:密码的格式,证明我们之......
  • python 使用waitress替代flask自带的web服务器
    首席引入依赖安装waitrsspipintsllwaitress 然后在flask程序内引入依赖使用server()函数代替app.run()函数启动时,直接pythonxxx.py即可fromwaitressimportservefromflaskimportFlaskapp=Flask(__name__)@app.route('/')defhello_world():return'HelloWor......