iT邦幫忙

2024 iThome 鐵人賽

DAY 12
0

概念

Logical Properties:基於邏輯方向而非物理方向來進行佈局。

在一段文字開頭處,想加上一個 icon 做裝飾,這個 icon 距離文字要有 20px,且距離下一個新段落要有 50px 的間距!

文字開頭處下一個新段落

如果網站是單一語系,例如:英文,可以直接在 icon 元素使用 margin-right: 20px,然後在段落元素上使用 margin-bottom: 50px

但如果網站屬於多語系的話,要再多考慮:

  1. 文字的書寫方向
  2. Flow 的方向

因為每一種語言書寫的方式不太一樣,例如:

  • 英文,由左至右書寫,往下接續新的一行
  • 阿拉伯文,由右至左書寫,往下接續新的一行
  • 文字也有從上至下書寫的,例如:中文、韓文、日文,往左接續新的一行
  • 傳統蒙古語也是上到下書寫,但是往右接續新的一行

logical properties 讓屬性是相對於內容書寫方向而定,而非真正在畫面上看到的上下左右

開頭處,不一定是頁面的左上,下一個新段落也不一定是往下接續

block dimension & inline dimension

logical properties 使用 blockinline 來描述 flow 的方向

block dimension:指文字流動的垂直方向 (新段落、新區塊的方向)
inline dimension:文字流動的平行方向 (單行文字的書寫方向)

  • block-start
  • block-end
  • inline-start
  • inline-end

https://ithelp.ithome.com.tw/upload/images/20240919/20128122GuX8mDDg6t.png
圖取自Logical layout enhancements with flow-relative shorthands

例如,margin-top 代表著物理方向的 top,不管使用的語言或是 writing mode,一律都在上方。如果使用 logical properties 就會變成 margin-block-start,隨著不同語言,會在 block flow 開頭處加上 margin。對區塊由上至下書寫的英文而言,margin 會在上方;對區塊由右至左書寫的日文而言,margin 會在畫面的右方。

補充

不用物理世界上下左右的方向,改用 inline 或是 block 這樣 flow 的方向來描述屬性
https://ithelp.ithome.com.tw/upload/images/20240921/20128122V5jploblCD.png
圖取自 CSS-Tricks - CSS Logical Properties and Values


參考資源

MDN Web Docs - CSS logical properties and values


上一篇
Grid
下一篇
Spacing
系列文
一個人的朝聖:重啟對 CSS 的認識30
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

尚未有邦友留言

立即登入留言