自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

CSS魔法!如何將任意CSS類型轉(zhuǎn)換為數(shù)值?

開發(fā) 前端
如何通過 CSS 獲取當前字號呢?根據(jù)上一節(jié)的原理,只要通過Tan() 和Atan2()就可以將任意長度轉(zhuǎn)換為數(shù)值了。

在 CSS 中有各式各樣的類型值,例如 1rem、10vw、100cqw等等,這些相對值給與了 CSS 強大的適應(yīng)能力。但有時候,我們還需要知道這些相對值所對應(yīng)的真實值,也就是px值,比如在移動端,我們經(jīng)常會設(shè)置這樣的根字號:

:root{
  font-size: max(12px, min( 12px + (100vw - 320px) / 55 * 4, 20px ));
}
p{
  font-size: 2rem;
}

那么,p此時的真實px值應(yīng)該是多少呢?

在以往,我們只能通過 JS去獲取,但是現(xiàn)在,僅僅憑 CSS也能做到,一起了解一下吧!

一、CSS 三角函數(shù)

從理論上來講,將一個長度除以1px就應(yīng)該得到具體的數(shù)值,相當于將這個長度以1px被分成了多少份。

2rem / 1px

但是,大家可能都知道,calc在進行除法運算時,除數(shù)是不能帶單位的。

calc(2rem / 1px) /*不合法*/

不排除瀏覽器以后會支持。

不過現(xiàn)在終于迎來了轉(zhuǎn)機,在 Chrome 111中,CSS 新增了一系列三角函數(shù)。

  • sin()[1]:正弦
  • cos()[2]:余弦
  • tan()[3]:正切
  • asin()[4]:反正弦
  • acos()[5]:反余弦
  • atan()[6]:反正切
  • atan2()[7]:反正切

這里我們不聊三角函數(shù)的作用,只是作為一個橋梁中轉(zhuǎn)一下。

關(guān)于「正切函數(shù)」,這里簡單回顧一下高中數(shù)學

在「直角三角形」中,其中一個銳角的「對邊」和「臨邊」的比值就是這個角的「正切值」,「反正切」就是通過兩條直角邊反向去求出該角的「弧度值」,示意如下:

這些函數(shù)本身沒什么特別的,業(yè)界通用,但有一個非常例外,那就是atan2,它和atan作用是一樣的,都是反正切函數(shù)。唯一的區(qū)別是,atan2支持兩個值

前端中的 atan 就是數(shù)學中的 arctan。

atan2(y, x)

例如:

transform: rotate(atan2(3, 2));
/*等同于*/
transform: rotate(atan(1.5));

看似好像沒啥意義,直接用tan不就好了?

transform: rotate(atan2(3/2));

和JS不同的是,CSS 中還能「支持單位」,如下:

transform: rotate(atan2(1rem, 20px));
/*等同于?*/

這就不得了了,如果此時的1rem是16px,那么瀏覽器會根據(jù)1rem的真實長度和20px做對比,相當于讓兩個帶單位的長度做除法運算。

/*等同于*/
transform: rotate(atan(.8)); /* 16px / 20px */

也就是說,y/x的值可以得到兩個CSS長度之間的真實比值,而無需額外轉(zhuǎn)換。

然后,通過正切函數(shù)tan將括號里面的值解析出來。

tan(atan2(1rem, 20px)) /*.8*/

這一點其實在 JS 中也可以驗證一下,只是 CSS 可以帶單位的值。

如果將后面的值設(shè)置為1px,就相當于把任意長度按照1px進行切分,也就得到了任意長度的px數(shù)值,如下:

tan(atan2(1rem, 1px)) /*16*/

有了這個不帶單位的絕對值,我們就可以做很多事情了,下面舉幾個例子。

二、CSS 獲取當前字號

回到文章開頭的問題,如何通過 CSS 獲取當前字號呢?

根據(jù)上一節(jié)的原理,只要通過tan() 和 atan2()就可以將任意長度轉(zhuǎn)換為數(shù)值了。

:root{
  font-size: max(12px, min( 12px + (100vw - 320px) / 55 * 4, 20px ));
}
body{
  --px-font: tan(atan2(1rem, 1px));
}

這樣--px-font就得到了真實的px數(shù)值。

然后,我們還可以借助 CSS計數(shù)器,將這個數(shù)字渲染到頁面。

body::after{
  counter-reset: font var(--px-font);
  content: "當前根字號:" counter(font);
}

結(jié)果...效果如下:

好像不太對?貌似是瀏覽器的 bug,這種情況下忽略了tan(atan2(1rem, 1px))中的1rem單位。

要修復這個問題其實很容易,需要通過@property定義一個CSS變量,類型為長度,然后將需要計算的值賦給這個變量,如下:

@property --font {
  syntax: "<length>";
  initial-value: 1px;
  inherits: false;
}
:root{
  font-size: max(12px, min( 12px + (100vw - 320px) / 55 * 4, 20px ));
}
body::after{
  --font: 1rem; /*定義好的CSS變量*/
  --px-font: tan(atan2(var(--font), 1px));
  counter-reset: font var(--px-font);
  content: "當前根字號:" counter(font);
}

這樣就正常了,在改變屏幕尺寸時會自動渲染出當前字號。

你也可以訪問在線鏈接

  • CSS font-size (juejin.cn)[8]
  • CSS font-size (codepen.io)[9]

三、實時顯示容器尺寸

CSS容器查詢中出現(xiàn)了幾個新的尺寸單位。這里只介紹下面兩種。

關(guān)于容器查詢,可以參考這篇文章:介紹2022最期待且已正式支持的CSS container容器查詢 ? 張鑫旭-鑫空間-鑫生活 (zhangxinxu.com),本文并不涉及具體容器查詢語句。

  • 「cqw」 容器查詢寬度(Container Query Width)占比?!?cqw等于容器寬度的1%」。假設(shè)容器寬度是1000px,則此時1cqw對應(yīng)的計算值就是10px。
  • 「cqh」 容器查詢高度(Container Query Height)占比?!?cqh等于容器高度的1%」。

利用前面的技巧,可以將cqw、cqh這些單位轉(zhuǎn)換為具體的px值。

假設(shè)有這樣一個容器。

.box{
  display: grid;
  place-content: center;
  width: 200px;
  height: 200px;
  background-color: #fff;
}

為了使容器尺寸生效,必須聲明容器類型。

.box{
  /**/
  container-type: size;
}

然后用同樣的技巧,在偽元素中通過計數(shù)器將寬高渲染出來。

.box::before{
  --w: 100cqw;
  --h: 100cqh;
  --px-width: tan(atan2(var(--w), 1px));
  --px-height: tan(atan2(var(--h), 1px));
  counter-reset: w var(--px-width) h var(--px-height);
  content: counter(w) " x " counter(h);
}

別忘了修復 bug。

@property --w {
  syntax: "<length>";
  initial-value: 100px;
  inherits: false;
}
@property --h {
  syntax: "<length>";
  initial-value: 100px;
  inherits: false;
}

效果如下,完全沒有任何 JS。

你也可以訪問在線鏈接

  • CSS resize (juejin.cn)[10]
  • CSS resize (codepen.io)[11]

四、自適應(yīng)文本的頭像

下面看一個自適應(yīng)文本的頭像,當文本較多時,會自動縮放,讓文本可以完整展示,如下

原理其實是通過容器尺寸的映射關(guān)系來動態(tài)設(shè)置文本大小,關(guān)鍵實現(xiàn)如下:

.avator-container span {
  font-size: calc( 24px - 10cqw );
}

但是,通過文字大小來縮放有一個限制,在PC上,一般會有最小字號限制(通常是12號),所以更好的方式應(yīng)該是通過scale來實現(xiàn)。

現(xiàn)在,我們可以通過上面的技巧,將容器尺寸轉(zhuǎn)換成scale能夠識別的數(shù)值,通過文本寬度和容器尺寸的比值來確實縮放比例,關(guān)鍵實現(xiàn)如下:

.avator-container span {
  --w: 100cqw;
  --scale: tan(atan2(30px, var(--w)));
  transform: scale(var(--scale));
}

這樣就得到了完全自適應(yīng)尺寸的文本頭像了。

完整代碼可以訪問在線鏈接

  • CSS auto text avator (juejin.cn)[12]
  • CSS avator auto scale (codepen.io)[13]

五、總結(jié)一下

以上就是本文的全部內(nèi)容了,介紹了一個非常巧妙并且有用的 CSS 小技巧,下面總結(jié)一下

  • CSS 有很多類型的尺寸,這些尺寸給與了 CSS 強大的適應(yīng)能力。
  • 從理論上講,將一個長度除以 1px 就可以得到具體的數(shù)值,但是calc不支持。
  • CSS 反正切函數(shù) atan2(y,x) 支持兩個參數(shù),并且還支持帶CSS單位。
  • 通過 tan(atan2(y,x))可以得到y(tǒng)/x的比值,如果x是1px,可以得到y(tǒng)的實際px值。
  • 利用這個技巧,可以將任意類型值轉(zhuǎn)換為數(shù)值。
  • 純數(shù)值可以在各個地方都可以使用了,比如scale(var(--n)),如果需要 px,直接calc(var(--n) * 1px )。

參考資料:

[1]sin(): https://developer.mozilla.org/zh-CN/docs/Web/CSS/sin。

[2]cos(): https://developer.mozilla.org/zh-CN/docs/Web/CSS/cos。

[3]tan(): https://developer.mozilla.org/zh-CN/docs/Web/CSS/tan。

[4]asin(): https://developer.mozilla.org/zh-CN/docs/Web/CSS/asin。

[5]acos(): https://developer.mozilla.org/zh-CN/docs/Web/CSS/acos。

[6]atan(): https://developer.mozilla.org/zh-CN/docs/Web/CSS/atan。

[7]atan2(): https://developer.mozilla.org/zh-CN/docs/Web/CSS/atan2。

[8]CSS font-size (juejin.cn): https://code.juejin.cn/pen/7289041195483791416。

[9]CSS font-size (codepen.io): https://codepen.io/xboxyan/pen/XWoObZX。

[10]CSS resize (juejin.cn): https://code.juejin.cn/pen/7289046442864279591。

[11]CSS resize (codepen.io): https://codepen.io/xboxyan/pen/MWZLYZz。

[12]CSS auto text avator (juejin.cn): https://code.juejin.cn/pen/7289095309752270906。

[13]CSS avator auto scale (codepen.io): https://codepen.io/xboxyan/pen/qBLLexW。

責任編輯:姜華 來源: 前端偵探
相關(guān)推薦

2009-07-15 16:56:59

Jython類型Java類型

2009-06-05 11:16:58

字符串動態(tài)轉(zhuǎn)換

2010-08-27 09:11:20

XHTMLCSS

2020-12-17 08:08:15

CentOS

2024-02-19 15:38:08

JsonPython字符串

2017-05-25 15:14:36

2009-07-31 14:09:41

c#時間格式轉(zhuǎn)換

2024-05-30 08:40:41

大型語言模型LLM人工智能

2021-12-29 16:40:54

Python語言字符串

2020-04-06 20:30:37

JavaScriptBoolean開發(fā)

2016-10-19 15:15:26

2024-01-04 09:17:03

前端開發(fā)CSV 格式JSON 字符串

2010-09-13 09:47:25

XHTML/CSS

2011-04-08 10:16:13

文本文件ACCESS數(shù)據(jù)庫

2009-11-25 16:55:45

PHP函數(shù)explod

2022-05-11 17:21:05

Btrfs文件系統(tǒng)Fedora

2018-09-10 15:14:27

前端WebURL

2021-10-29 15:13:21

LinuxPDF文件

2022-10-12 08:00:00

語音識別Node.js音頻質(zhì)量

2024-02-28 09:57:30

C++類型強制轉(zhuǎn)換開發(fā)
點贊
收藏

51CTO技術(shù)棧公眾號