css的2D转换

算法内卷
• 阅读 1174

脚本化css
下面通过css实现动画效果,可以使用脚本化的css实现滑入,轮廓伸缩的列表,即动态的HTML,一个过时的说法DHTML

一些css的基础知识

之前已经看过厚厚的一本大书,现在简单看一下,补充一下不知道的点

层叠

web浏览器组合元素的style属性,然后再计算样式。

颜色透明度和半透明

颜色有半透明的颜色(不知道为什么edge不兼容)

脚本化内联样式

div.style.background = "#FFFFFF"

即通过js完成css样式的添加

由于-会被js认为有语法错误,所以-统一在js中变成驼峰命名法进行命名。这是一种习惯

同样的也可以直接使用属性进行设置

e.setAttribute

进行设置css的内联样式

其实是通过增加css的属性的内联样式达到效果的。即style的值

style的权重要大于任何的样式,所以用js生成的style的样式的值,一直起作用,除非刻意的更改其权重。

css的2d转换

即,进行一些css的转换

坐标

描述坐标的系统有笛卡尔坐标系统和齐次坐标系。

笛卡尔坐标系

用一组数值在一组平面上表示一个点。其坐标为右手法则(在三维上)
更多 https://en.wikipedia.org/wiki...
其下方的变换是基于笛卡尔坐标系进行变换
通过将点用矩阵进行表示,对矩阵进行变换,(线性的变换)得到相应的结果。例如进行乘法变换,加法变换等等。

transform

属性将会允许修改CSS视觉格式模型的坐标空间。使用它,元素可以被转换(translate)、旋转(rotate)、缩放(scale)、倾斜(skew)。 只对块级元素生效

原点

有三个值,一个值为x轴,一个值为y轴,一个值为z轴。
如下图所示
css的2D转换
每个值可以进行设置,此为旋转原点
具体的值为transform-origin
如果未指定初始值,将会直接使用继承。

演示

https://developer.mozilla.org...

rotate旋转

该方法定义了一种将元素围绕一个定点,该定点由transform-origin指定元素变形的原点。

单位 angle

一种css的基本数据类型。angle表示角的大小,单位为度(degrees)百分度(gradians)弧度(radians)圈数(turns)
deg 度
grad 百分度 (复习一下数学,一种角的测量单位,定义为将一个圆切成400等分,也就是一个直角等于100百分度 https://zh.wikipedia.org/wiki...
rad 弧度 (复习一下数学 https://zh.wikipedia.org/wiki...
turn 圈数

不列颠百科全书 https://www.britannica.com/bi...
语法

数字与单位之间没有空格。数字为0时,单位可以省略。
使用+号或者-号开头,正数表示顺时针的角,负数表示逆时针的角。

一些例子

90deg = 100grad = 0.25trun ≈ 1.57rad(约等于π/2)
所有的如下表示
css的2D转换

一个旋转说明

css的2D转换

缩放 scale

一个css函数scale()用于缩放。用于修改元素的大小,通过向量形式定义的缩放值来放大和缩小元素。有两个值,一个值为sx,一个值为sy,根据两个值得出结果。如果sy未设置,将会直接用sx的值设置sy的值。其单位为css数据类型中的number

该缩放仅仅支持欧几里得平面(二维平面)上的变换

css的2D转换

设置的css的值为

transform: scale(2, 2);

至此,完成了一个横轴一倍,纵轴一倍的放大。
同理,缩小也可以。

倾斜 skew

为一个偏斜的二维平面上的原件变化,其结果为数据类型。

剪切映射

css的倾斜为剪切映射,每个点的坐标由与指定角度或成比例的值到原点的距离。对于每个坐标产生矩阵,然后对矩阵进行运算,得出运算后的坐标值。
css的2D转换
css的2D转换

css的3d转换

坐标

齐次坐标系

由笛卡尔坐标系投影得到。

  1. 投影平面中的任何点由三元组(x,y,z)表示,称为点的齐次坐标和投影坐标
  2. 如果坐标乘以公因子,则给定的一组齐次坐标点不变
  3. 相反,当且仅当通过所有坐标乘以相同的非零常数,从另一个获得一个时,两组齐次坐标表示相同的点
  4. 当z不为0时,表示的点为欧几里得的点。
  5. 当z为0时表示的点为无穷远处的点

更多 https://en.wikipedia.org/wiki...

rotateX()

围绕x轴进行旋转
css的2D转换
ps;设置的原点值为center

transform-origin:center;

rotateY()同理

3d组合不可进行交换,如果进行交换会导致出现不同的效果。
点赞
收藏
评论区
推荐文章
徐小夕 徐小夕
3年前
前端: 如何更高效的学习Css? 有哪些库值得推荐?
之前有很多朋友问我如何快速学习css以及有哪些好用的css库,最近也抽出时间思考整理了一下,今天就和大家分享一下我的经验.如何高效学习Css之前在工作中也使用css做过很多有意思的事情,比如用css画图标,写轮播图,写动效,做布局等等,但是这些应用的实现都依赖于html和css基础知识.根据我自己的学习经验,我们需要掌
VUE 实现一个简易老虎机
今天突然要做一个竖直滚动老虎机,可以设置中奖位置,以及中奖回调,然后再带点常规的滚动动画,还是有点意思,和之前的转盘抽奖有点类似,有兴趣可以看下。简单分析下UI,ui的话,就简单点,三个列表从下往上滚动,搞个框罩住css的活,应该简单。动画,老规矩,我们采用之前的方案,动态设置css,可以搞定。设置中奖位置,我们可以想传递
凯特林 凯特林
4年前
你可能不知道的10个CSS新功能(2021版)
多年来,CSS已经超越了背景颜色、边框、文本样式、边距和盒模型。现代CSS能够提供一系列的功能,而在过去,您需要JavaScript或变通方法来实现这些功能。为了庆祝它在2021年取得的成就,在这篇文章中,我们想看看一些你可能不知道的令人惊叹的CSS新特性。我们将强调web设计人员和开发人员可以用现代CSS做的很酷的事情,讨论用例,浏览器支持,并给你一个
徐小夕 徐小夕
5年前
如何使用css3实现一个类在线直播的队列动画
之前在群里有个朋友问了这样一个问题,就是如何在小程序中实现类似直播平台的用户上线时的队列动画?作为一名前端工程师,解决方案无非以下2种:1.使用javascript根据条件来控制元素的样式实现队列动画2.用纯css3配合数据驱动模型来实现.大家都知道在现代的Web开发中,我们能使用Css实现的效果尽量不要用Js,所以我们应该优先考虑用C
徐小夕 徐小夕
5年前
《前端实战总结》之使用纯css实现网站换肤和焦点图切换动画
今天我们来继续复盘一些工作中常用的css技巧和知识,以便我们可以更加优雅的用css实现富有动感的网站.你将收获网站换肤设计方案介绍:target伪类介绍和用法以及如何使用css实现网站换肤transition动画以及如何用纯css实现焦点图动画效果展示1.网站换肤(https://imghelloworld.ossc
徐小夕 徐小夕
5年前
《前端实战总结》之使用CSS3实现酷炫的3D旋转透视
3D动画效果现在越来越普及,已经被广泛的应用到了各个平台,比如阿里云,华为云,webpack官网等。它可以更接近于真实的展示我们的产品和介绍,带来极强的视觉冲击感。所以说,为了让自己更加优秀,css33D动画必不可少。你将学到CSS33D转换的常用API介绍CSS33D应用场景CSS33D实现一个立方体开始1.CSS
Stella981 Stella981
4年前
Javascript基础知识学习(三)
前言:javascript是一种轻量的、动态的脚本语言,我们为什么要使用javascript?对于一个网页的设计,.html用来放置网页的内容,.css则用来设计网页的样式和布局,那么.js它主要是使网页能够产生交互,意思就是能够通过代码动态的修改HTML、操作CSS、响应事件、获取用户计算机的相关信息等。javascript不是所有的浏览器
Stella981 Stella981
4年前
Python+Selenium练习篇之5
前面介绍了,XPath,id,class,linktext,partiallinktext,tagname,name七大元素定位方法,本文介绍webdriver支持的最后一个方法:by\_css。css和XPath类似,也需要掌握一些语法,才能写出正确的,完整的css选择表达式。相关脚本代码如下:codingu
Wesley13 Wesley13
4年前
CSS基本用法介绍
CSS介绍css定义如何显示HTML元素.当浏览器读到一个样式表,它就会按照这个样式表来对文档进行格式化(渲染).CSS语法css实列每个CSS样式由两个组成部分:选择器和声明。声明又包括属性和属性值。每个声明之后用分号结束。css注释/这是注释/CSS的几种引入方
Stella981 Stella981
4年前
CSS 分类 (Classification)
★★CSS分类属性(Classification)★★⑴CSS分类属性允许你控制如何显示元素,设置图像显示于另一元素中的何处,相对于其正常位置来定位元素,使用绝对值来定位元素,以及元素的可见度。⑵下面是常用的属性以及描述:!(https://oscimg.oschina.net/oscnet/00cb565
算法内卷
算法内卷
Lv1
入春才七日,离家已二年。
文章
3
粉丝
0
获赞
0