atan()

Baseline 已广泛支持

此功能已成熟,并可在许多设备和浏览器版本上运行。自 2023 年 3 月以来,它已在各种浏览器中可用。

atan() CSS 函数是一个三角函数,它返回一个介于 -∞+∞ 之间的数字的反正切值。该函数包含一个计算,该计算返回表示介于 -90deg90deg 之间的 <angle> 的弧度数。

语法

css
/* Single <number> values */
transform: rotate(atan(1));
transform: rotate(atan(4 * 50));

/* Other values */
transform: rotate(atan(pi / 2));
transform: rotate(atan(e * 3));

参数

atan(number) 函数只接受一个值作为其参数。

数字

一个计算结果为介于 -∞+∞ 之间的 <number>

返回值

一个 number 的反正切值将始终返回一个介于 -90deg90deg 之间的 <angle>

  • 如果 number0⁻,则结果是 0⁻
  • 如果 number+∞,则结果是 90deg
  • 如果 number-∞,则结果是 -90deg

也就是说

  • atan(-infinity) 代表 -90deg
  • atan(-1) 代表 -45deg
  • atan(0) 代表 0deg
  • atan(1) 代表 45deg
  • atan(infinity) 代表 90deg

正式语法

<atan()> = 
atan( <calc-sum> )

<calc-sum> =
<calc-product> [ [ '+' | '-' ] <calc-product> ]*

<calc-product> =
<calc-value> [ [ '*' | / ] <calc-value> ]*

<calc-value> =
<number> |
<dimension> |
<percentage> |
<calc-keyword> |
( <calc-sum> )

<calc-keyword> =
e |
pi |
infinity |
-infinity |
NaN

示例

旋转元素

atan() 函数可以用于 旋转 元素,因为它返回一个 <angle>

HTML

html
<div class="box box-1"></div>
<div class="box box-2"></div>
<div class="box box-3"></div>
<div class="box box-4"></div>
<div class="box box-5"></div>

CSS

css
div.box {
  width: 100px;
  height: 100px;
  background: linear-gradient(orange, red);
}
div.box-1 {
  transform: rotate(atan(-99999));
}
div.box-2 {
  transform: rotate(atan(-1));
}
div.box-3 {
  transform: rotate(atan(0));
}
div.box-4 {
  transform: rotate(atan(1));
}
div.box-5 {
  transform: rotate(atan(99999));
}

结果

规范

规范
CSS 值和单位模块第 4 级
# trig-funcs

浏览器兼容性

另见