前言

之前写的 W3Schools 学习笔记 (3) – CSS 2D Transforms. 这篇作为整理.

参考:

Youtube – Learn CSS Transform In 15 Minutes

Demo Structure

<div class="frame"></div>
<div class="box">Box1</div>

一个作为框, 这样变化的时候可以对比.

CSS Style

.frame,
.box {
position: absolute;
top: 50px;
left: 50px;
width: 200px;
height: 200px;
}
.frame {
border: 1px solid black;
}
.box {
background-color: pink;
display: flex;
justify-content: center;
align-items: center;
color: blue;
font-size: 2rem;
}

效果

Rotate

旋转 30°

transform: rotate(30deg);

效果

注意它的轴在中心的位置. 这个是可以改变的哦 (下面会说到)

Scale

transform: scale(0.8);

1.0 是原 size, 0.8 (< 1) 是缩小. > 1 是放大.

注意它的轴在中心的位置. 往中心点缩放 (下面会说到).

transform-origin

这个就是控制轴心的. 适用于 rotate 和 scale. translate 就没差 (效果都一样)

transform: rotate(30deg);
transform-origin: top left;

top left 表示方位 vertical horizontal (y, x).

分别是, top left, top center, top right 的效果. 红色圈就是所谓的 origin. 可以看出来不同 origin 旋转的效果就不一样了.

scale 也是同一个逻辑

transform: scale(1.3);
transform-origin: 50px 150px;

做地图缩放通常会用到第 3 个.

Translate

transform: translate(50px, 20px);

horizontal, vertical (x, y)

它和 origin 没有什么关系, 因为不管在那个点移动都是一样的.

use percent

transform: translate(50%, 50%);

它会依据 width 和 height 计算出 percent, 效果:

居中

想实现的效果是 Hello World 在正中间.

HTML 结构

<div class="container">
<img src="./images/tifa2.PNG" />
<h1>Hello World</h1>
</div>

不使用 background-image

img {
width: 100%;
height: 100%;
object-fit: cover;
} .container {
width: 400px;
height: 250px;
position: relative;
} h1 {
position: absolute;
top: 50%;
left: 50%;
color: white;
}

让 h1 绝对定位. top:50%, left 50% 这样就去到中间了.

但是过龙了. 通过 translate 把它桥回来.

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

效果

Single Property

参考: web.dev – Finer grained control over CSS transforms with individual transform properties

由于 transform 是把所有调整放在一个值上, 当我们想要单独调整 transform 中的其中一个时就很麻烦.

目前的 solution 是通过 CSS Variable.

transform: scale(var(--scale)) translateX(var(--translateX))

这样就可以单独修改某个 variable 来达成效果.

但最新的 CSS 语法已经开始支持单独属性了.

比如 : translate, scale, rotate

modern browser 都支持, 包括 Safari IOS 14.5 (大约 iPhone 7) 就支持了, for 旧的 browser PostCSS 虽然有 plugin 可以做转换, 但这个是 7 years ago 的, 不建议使用了.

Single Property vs Transform

参考: How They Fit Together: Transform, Translate, Rotate, Scale, and Offset

Single Property 并不能完全取代 Transform 的功能.

1. Transform 的顺序是依据我们定义的顺序执行的. 但是 Single Property 是固定的 translate > rotate > scale

2. Transform 内可以重复定义, 但是 Single Property 只能定义一次.

总的来说 Transform 是一组有序的操作. 它就挨个挨个执行. 重复也可以

Single Property 则只可以定义 translate, rotate, scale 一次, 然后它按原本的顺序执行一轮.

冷知识 – Transform, Opacity 也会让元素飘起来

CSS – Transform的更多相关文章

  1. No.3 - CSS transition 和 CSS transform 配合制作动画

    课程概述 作业提交截止时间:09-01 任务目的 深度理解掌握 transition-timing-function 以及它的意义 学会配合使用 CSS transform 和CSS transiti ...

  2. CSS Transform / Transition / Animation 属性的区别

    back21 Jun 2011 Category: tech Tags: css 最近想UI的动画转到css3能吃进3d加速的属性上面来以加强动画的连贯性.只是对于css几个新加的属性不太熟悉,常常容 ...

  3. Html CSS transform matrix3d 3D转场特效

    Html CSS transform matrix3d 3D转场特效 透视矩阵 2n/(r-l) 0 (r+l)/(r-l) 0 0 2n/(t-b) (t+b)/(t-b) 0 0 0 (n+f)/ ...

  4. css: transform导致文字显示模糊

    css: transform导致文字显示模糊 有人认为模糊的原因是:"transform时div的宽度或者高度并不是偶数,偏移 50% 之后,像素点不是整数,和显示像素没有对上". ...

  5. CSS Transform完全指南 #flight.Archives007

    Title/ CSS Transform完全指南 #flight.Archives007 序: 第7天了! 终身学习, 坚持创作, 为生活埋下微小的信仰. 我是忘我思考,共同进步! 简介: 一篇最简约 ...

  6. CSS Transform完全指南(第二版) #flight.Archives007

    Title/ CSS Transform完全指南(第二版) #flight.Archives007 序: 第7天了! 终身学习, 坚持创作, 为生活埋下微小的信仰. 我是忘我思考,共同进步! 简介: ...

  7. CSS Transform让百分比宽高布局元素水平垂直居中

    很早以前了解过当元素是固定宽度和高度的时候,水平垂直高居中的方法可以设置margin的负值来使其居中,这个负值是元素的宽和高的一半,比如宽高是100px,那么就用margin-left:-50px;m ...

  8. CSS Transform Style

    As CSS3 developing quickly, the transform style can be written conviently. I find that it is an inte ...

  9. CSS transform中的rotate的旋转中心怎么设置

    transform-origin属性 默认情况,变形的原点在元素的中心点,或者是元素X轴和Y轴的50%处.我们没有使用transform-origin改变元素原点位置的情况下,CSS变形进行的旋转.移 ...

  10. CSS+transform画动态表情

    先给大家看下画完后是什么样子: 代码看这里: html代码: <body> <div class="emoji emoji_like"> <div c ...

随机推荐

  1. 【原创软件】第7期:文件夹生成器V1.0-按照列表批量生成文件夹,简单小巧

    一.背景 因为工作需要,需要批量创建文件夹.为了省去人工创建时间,使用aardio制作了一个软件. 二.功能演示 三.下载地址  https://www.123pan.com/s/9Rn9-1xppH ...

  2. 【数据集】Maple-IDS——网络安全恶意流量检测数据集

    一.数据集介绍 Maple-IDS数据集是一个网络入侵检测评估数据集,旨在增强异常基础入侵检测系统(IDS)和入侵预防系统(IPS)的性能和可靠性.随着网络空间安全领域攻击的日益复杂化,拥有一个可靠和 ...

  3. 使用Cloudflare Worker加速docker镜像

    前言 开发者越来越难了,现在国内的docker镜像也都️了,没有镜像要使用docker太难了,代理又很慢 现在就只剩下自建镜像的办法了 GitHub上有开源项目可以快速搭建自己的镜像库,不过还是有点麻 ...

  4. 【教程】重启Windows文件资源管理器

    [教程]重启Windows文件资源管理器 打开任务管理器 以下方法任选其一: 方法一 :组合键 Ctrl + Shift + ESC (个人推荐) 方法二 :组合键 Win + X (或右键Windo ...

  5. Windows下搭建Vue脚手架CLI

    Vue CLI的使用依赖Node.js,先按照Node.js环境. //安装环境C:\Users\16779>npm install --global vue-cli npm WARN depr ...

  6. GeoScene Enterprise 3.1 临时许可更新

    Portal许可更新 portal 的许可更新很简单,直接打开Portal在线更新就好了 平台管理 -> 许可管理 -> 附加许可 -> 导入许可 -> 选择文件(选择授权的j ...

  7. 【Kafka】02 原生集群部署

    基于大数据教程的环境: 192.168.101.11 centos7-01 192.168.101.12 centos7-02 192.168.101.13 centos7-03 搭建Kafka环境需 ...

  8. 【Redis】06 事务

    Redis事务 可以一次执行多个命令,本质是一组命令的集合. 一个事务中的 所有命令都会序列化,按顺序地串行化执行而不会被其它命令插入,不许加塞 官方说明: https://redis.io/topi ...

  9. 【转载】 tf.slice()介绍

    原文地址: https://blog.csdn.net/nini_coded/article/details/79852031 版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议, ...

  10. 【转载】 vim中常用折叠命令

    原文地址: https://www.cnblogs.com/litifeng/p/11675547.html 个人推荐的一个视频教程地址: 上古神器Vim:从恶言相向到爱不释手 - 终极Vim教程01 ...