您好,登錄后才能下訂單哦!
本篇內容介紹了“CSS常用函數介紹”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
簡介
CSS 包含了許多函數,而且它能夠完成許多早期需要用 JavaScript才能完成的事情。每年都有新的特性被添加進來,這讓我們的開發更加輕松,也減少了對JavaScript的依賴。CSS 函數是它所具有的最強大的特性之一,在本文中,我將介紹一些我認為有用的函數。
attr()
attr 函數用于獲取所選元素的屬性值。它接受三個參數,屬性名稱,類型和默認值。
語法: attr( attribute-name? [,]? )
事例:
<p data-text="the attr function" data-tooltip="Hi from attr!" class="attr">This text is combined with</p>
css
p::after { content: ' ' attr(data-text); } p.attr:hover::after { content: ' ' attr(data-tooltip); background-color: orange; color: white }
效果:
源碼:https://codepen.io/protic_milos/pen/GRpYJKd
calc()
這個函數使我們能夠計算CSS值,而不是指定確切的值。通常用于計算元素的大小或位置。它支持加法、減法、乘法和除法。
需要特別注意重要一點是+和-運算符必須用空格隔開,不然無法正常工作。*和/運算符不有這限制,但出于一致性的考慮,建議添加空格。
另外,很棒的是,我們可以混合CSS單位,例如,我們可以減去百分比和像素。
我們可以用calc構建一個帶有居中元素的示例:
<p class="calc">Centered with calc</p>
css
p.calc { padding: 10px; background-color: orange; color: white; width: 200px; text-align:center; margin-left: calc(50% - 100px) }
效果:
源碼:https://codepen.io/protic_milos/pen/GRpYJKd
var()
通過這個函數,我們可以使用一個自定義屬性的值作為另一個CSS屬性的值。簡單地說,我們可以定義一個顏色,例如,將它放在自定義屬性(CSS變量)中,然后通過調用var函數重用該屬性值。
與CSS變量一起,該函數提高了可維護性并減少了重復。一個用例是為網站創建主題。
此函數接受兩個參數,即自定義屬性和一個默認值,如果出現問題,將使用它們。
:root { --bg-color: green; --color: white } p.var { background-color: var(--bg-color); color: var(--color) }
效果:
源碼:https://codepen.io/protic_milos/pen/GRpYJKd
counter()
就我個人而言,我從未使用過這種方法,但它看起來是很有趣。這個函數返回指定計數器的當前值,需要與 counter-reset和counter-increment 配合使用。
我們可以用它來計算其他元素,比如有序列表。
<div class="counter"> <span>Mars</span> <span>Bounty</span> <span>Snickers</span> </div>
源碼:https://codepen.io/protic_milos/pen/GRpYJKd
circle()
這個函數創建一個圓形區域來屏蔽它所應用的元素。你可以指定它的半徑和位置。通常與圖像一起使用來創建圓角形狀。此函數是clip-path屬性值。
另外,值得一提的是,除了圓之外,您還可以創建橢圓和多邊形形狀。
源碼:https://codepen.io/protic_milos/pen/GRpYJKd
總結
正如我之前多次提到的,在很多情況下,開發人員都忽視了CSS的可能性,因此失去了web站點的簡單性。每一年我們都可以依靠CSS為我們提供所需的設計能力,這很好,JavaScript 應該把注意力放在其他事情上,而不是設計上。
“CSS常用函數介紹”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。