以往如果要在 HTML 寫上有東西罩在某個元素上,我們可以利用 position 的關係把子層元素變得跟容器層一樣大,像是:
<div class="box">
<div class="mask"></div>
</div>
.box{ width: 400px; height: 250px; background: linear-gradient(to bottom, red, yellow); position: relative; } .mask{ position: absolute; background: rgba(0,0,0,.6); left:0; top:0; bottom:0; right:0; }
只是每次就都會需要 left, top, bottom, right 都寫才能把區塊的範圍固定住,而在 inset 出來之後就輕鬆很多,可以把它想像成跟 padding 之類 box-model 設定類似的東西,像是我上面的範例就可以改寫成這樣:
.mask{ position: absolute; background: rgba(0,0,0,.6); inset: 0; }
直接用一個值就可以同時設定 left, top, bottom, right:
因為 inset 跟 padding 那些很像,所以你也可以設定一個值到四個值,依序設定上右下左四個邊的值,像是:
.mask{ position: absolute; background: rgba(0,0,0,.6); inset: 0 10px 20px 30px; }
也可以搭配之前提到的 CSS 邏輯屬性寫法,用 inset-inline 與 inset-block 同時設定水平跟垂直的值:
.mask{ position: absolute; background: rgba(0,0,0,.6); inset-inline: 10px; inset-block: 20px; }
之後就用 inset 來簡化你的 CSS position 定位寫法吧。