- vừa được xem lúc

[CSS] Bài 17 - Hàm & Biến

0 0 10

Người đăng: Semi Art

Theo Viblo Asia

Trong bài này, chúng ta sẽ nói về một số hàm chức năng và biến trong CSS. Bài viết này được thực hiện sau khi mình đã đăng tải xong các bài giới thiệu về khía niệm biến và hàm trong JavaScript và cũng là trong lập trình máy tính nói chung. Vì vậy nên mình giả định là bạn đã biết hàm và biến là cái gì rồi. Ở đây chúng ta sẽ chỉ giới thiệu cú pháp trong CSS và làm các ví dụ để sử dụng thôi.

Các hàm trong CSS

Tuy không phải là một ngôn ngữ lập trình và không hỗ trợ nhiều cấu trúc điều kiện với khả năng xử lý logic linh hoạt. CSS vẫn cung cấp cho chúng ta nhiều hàm tiện ích hỗ trợ một số thao tác tính toán đơn giản. Các hàm này được sử dụng để cung cấp các giá trị đặc biệt cho nhiều thuộc tính khác nhau. Dưới đây là 2 liên kết tham khảo về danh sách các hàm trong CSS.

  • Tài liệu của W3schools bao gồm những hàm phổ biến nhất đang được hỗ trợ bởi phiên bản CSS hiện tại.
  • Tài liệu của Mozilla Developer Network bao gồm cả các hàm đang được thử nghiệm cho các phiên bản CSS sắp phát hành và được hỗ trợ bởi các trình duyệt nighty build cho các dev.

Ở đây chúng ta sẽ làm ví dụ giới thiệu một vài hàm phổ biến nhất. Khởi đầu với calc(). Hàm này được sử dụng để tính toán các biểu thức toán học do người viết code cung cấp và tạo ra giá trị số học linh động sử dụng cho các thuộc tính. Chúng ta sẽ thử phác họa một lưới nội dung thường được sử dụng trong các trang web bán hàng bằng các khối inline-block được quy định độ rộng width linh động với calc.

calc.css

.calc-grid { padding: 30px 15px; } .calc-card { display: inline-block; width: calc(100% / 4 - 10px); height: 210px; background: lightgray;
}

calc.html

<!doctype html>
<html lang="en">
<head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>A Grid created by Calc</title> <link rel="stylesheet" href="calc.css"> </head>
<body> <div class="calc-grid"> <div class="calc-card"></div> <div class="calc-card"></div> <div class="calc-card"></div> <div class="calc-card"></div> <div class="calc-card"></div> <div class="calc-card"></div> <div class="calc-card"></div> <div class="calc-card"></div> <div class="calc-card"></div> <div class="calc-card"></div> <div class="calc-card"></div> <div class="calc-card"></div> </div>
</body>
</html>

Xem kết quả hiển thị

Trong cách thực hiện dàn vị trí các khối như trên thì các thẻ .calc-card là các khối inline-block nên sẽ được trình duyệt web thiết lập vị trí trong dòng chảy nội dung như các từ trong một đoạn văn bản bên trong .calc-grid. Với font-size mặc định thì các từ sẽ cách nhau khoảng 5px. Lúc này nếu chúng ta muốn dàn một lưới nội dung với 4 cột thì sẽ cần độ rộng các khối là 100% / 4 và giảm đi vài px nữa để bù trừ cho word-spacing mặc định.

Hãy thử làm một ví dụ khác với hàm attr(). Hàm này được sử dụng để truy xuất giá trị thuộc tính của chính phần tử được chọn. Ở đây chúng ta cần cung cấp cho hàm tên của thuộc tính cần đọc.

attribute.css

.post-next:after { content: " (" attr(href) ")";
}

attribute.html

<article class="post"> <!-- Tiêu đề và nội dung chính của bài viết --> <a class="post-next" href="https://viblo.asia/p/css-bai-17-ham-bien-Eb85oABmZ2G">[CSS] Bài 17 - Hàm & Biến</a>
</article>

Xem kết quả hiển thị

Chúng ta vừa mới truyền vào hàm attr() biến href đã được định nghĩa sẵn bởi phần tử <a> được chọn. Dường như việc sử dụng biến trong CSS để lưu trữ một vài giá trị cần được sử dụng lại nhiều lần cũng có nhiều lợi ích. Hãy nói về các biến tự tạo trong CSS.

Các biến trong CSS

Trước hết chúng ta cần một trường hợp ví dụ. Giả sử thiết kế web của bạn dùng tone màu chính accent với một giá trị màu nào đó cho nhiều thành phần trên trang web. Có chỗ thì dùng accent làm màu nền, có chỗ thì dùng accent làm màu chữ, có chỗ lại dùng accent làm màu viền. Lúc này nếu như chúng ta xử bằng cách tạo các class tiện ích như Bootstrap để gắn vào các thành phần cần sử dụng thì code CSS sẽ như thế này.

colors.css

.bg-accent { color: royalblue; }
.border-accent { color: royalblue; }
.text-accent { color: royalblue; }

Khá tiện lợi rồi, nhưng khi mà chúng ta cần thay đổi accent bằng màu khác, ví dụ như cùng một thiết kế web nhưng hỗ trợ người dùng thay đổi tone màu chính của theme giống như Twitter đã từng làm. Lúc này chúng ta vẫn phải thay đổi giá trị màu ở nhiều nơi vì có nhiều class tiện ích. Thay vì vậy thì chúng ta có thể sử dụng một biến accent để lưu giá trị và dùng cho các class tiện ích này.

colors.css

body { --accent: royalblue;
} .bg-accent { color: var(--accent); }
.border-accent { color: var(--accent); }
.text-accent { color: var(--accent); }

Như bạn đã nhìn thấy trong code ví dụ, để định nghĩa một biến trong CSS, chúng ta sử dụng cú pháp là --tên_biến: giá_trị_gán;. Và biến này sẽ có phạm vi sử dụng là ở bất kỳ đâu bên trong phần tử body.

Bài viết về sử dụng hàm và biến trong CSS của chúng ta tới đây là kết thúc. Trong bài viết tiếp theo, chúng ta sẽ nói về bộ công cụ hỗ trợ canh chỉnh bố cục của các thành phần trong trang web. Trước đó thì chúng ta xử lý tác vụ này bằng position và rồi rất nhanh chóng chúng ta đã làm quen với Bootstrap. Tuy nhiên việc hiểu được các công cụ được cung cấp bởi CSS sẽ rất quan trọng để có thể sử dụng và tùy biến Bootstrap tự tin hơn.

Hẹn gặp lại trong bài viết tiếp theo.

(Sắp đăng tải)[CSS] Bài 18 - Grid & Flex & Float

Bình luận

Bài viết tương tự

- vừa được xem lúc

Căn giữa các phần tử HTML theo chiều dọc (phần 1)

Bài viết được dịch từ bài Vertical centering of elements in HTML xuất bản ngày 18/01/2015 trên trang Web++. .

0 0 79

- vừa được xem lúc

Căn giữa phần tử trong CSS

1. Theo chiều ngang. Đó có phải là phần tử inline hay inline-* (như text hay links). .

0 0 66

- vừa được xem lúc

99% không biết đến mẹo này khi sử dụng Flexbox CSS

Hello lại là mình đây. Bài viết hôm nay mình sẽ giới thiệu tới mọi người một trick khá hay khi dùng CSS flexbox nhé. 1. Chia layout với flexbox.

0 0 62

- vừa được xem lúc

Vanilla JS Project: Tính tuổi

1. Yêu cầu.

0 0 72

- vừa được xem lúc

1 số UI component và layout hữu ích với Frontend

Giới thiệu. Hôm nay mình xin chia sẻ 1 số Layout và UI component quen mà có lẽ là quen thuộc với nhiều người khi làm dự án, hay bắt gặp trên mạng.

0 0 65

- vừa được xem lúc

Style text css

Giới thiệu. Chào 2021, mình sẽ giới thiệu vài kiểu style cho text màu mè chút cho rực rỡ .

0 0 44