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

[CSS] Bài 5 - Các Thuộc Tính Background

0 0 9

Người đăng: Thịnh Trần

Theo Viblo Asia

Trong bài trước, chúng ta đã trang trí một vài container sử dụng thuộc tính background-color.
Tuy nhiên vẫn còn nhiều cách khác nữa để khiến các container trông đẹp mắt hơn.
Hãy cùng thảo luận thêm về các thuộc tính background.

Thiết lập hình nền cho một container

Chúng ta đã sử dụng thuộc tính background-color một vài lần trong bài hướng dẫn trước. Lần này chúng ta sẽ thiết lập hình nền của một container sử dụng thuộc tính background-image. Đây là cú pháp của thuộc tính này:

background-image: url(đường-dẫn-tới-tệp-ảnh);

Dạng của đường dẫn tới tệp ảnh sẽ tùy thuộc vào việc ảnh mà bạn sử dụng được lưu trữ cục bộ hay trên một trang web khác đâu đó trên internet. Trong code ví dụ phía bên dưới, chúng ta sẽ sử dụng một tấm ảnh đang được host tại imgur.

lovely.html

<!doctype html>
<html> <head> <meta charset="utf-8"> <title>A Lovely Day</title> <link rel="stylesheet" href="lovely.css"> </head> <body> <section class="card"> <h2 class="card-msg">A lovely daaay !</h2> </section> </body>
</html>

lovely.css

.card { display: inline-block; width: 320px; height: 360px; /* color is used in case browser cannot load image */ background-color: Crimson; /* use image as background */ background-image: url(https://i.imgur.com/sp2xQEy.png);
} .card-msg { text-align: center; color: White;
}

Chúng ta đã sử dụng một tấm hình có một cánh đồng trải dài. Nhưng phần đẹp đẽ của tấm hình lại bị ẩn đi vì kích thước của container nhỏ hơn rất nhiều so với kích thước của ảnh nền. Hãy cùng sửa lại trong phần tiếp theo.

Thuộc tính background-size

Thuộc tính background-size có thể được sử dụng với 1 trong 2 giá trị thông minh: covercontainer. Cả 2 giá trị này sẽ đều cố gắng khiến cho hình nền điều chỉnh phù hợp với kích thước của container.

Trong khi background-size: cover; sẽ giúp đảm bảo rằng hình nền luôn lấp kín diện tích của container,
thì background-size: container sẽ giúp đảm bảo rằng hình nền luôn được hiển thị đầy đủ trong container.

Hãy thử nhân đôi container mà chúng ta đang có và dùng thử cả 2 giá trị này.

lovely.html

<!doctype html>
<html> <head> <meta charset="utf-8"> <title>Another Lovely Day</title> <link rel="stylesheet" href="lovely.css"> </head> <body> <section class="card bg-cover"> <h2 class="card-msg">A lovely daaay !</h2> </section> <section class="card bg-contain"> <h2 class="card-msg">Another lovely daaay !</h2> </section> </body>
</html>

lovely.css

.card { display: inline-block; width: 320px; height: 360px; background-color: Crimson; background-image: url(https://i.imgur.com/sp2xQEy.png);
} .card-msg { text-align: center; color: White;
} .bg-cover { background-size: cover;
} .bg-contain { background-size: contain;
}

Như bạn đã thấy thì hình nền ở container thứ 2 có cùng độ rộng với container nhưng có chiều cao nhỏ hơn. Và theo mặc định thì trình duyệt web sẽ lặp hình nền để lấp đầy diện tích của container.

Để điều khiển việc lặp hình nền, chúng ta có thuộc tính background-repeat có thể được sử dụng với 1 trong 3 giá trị sau: repeat-x, repeat-y, và no-repreat. Bạn có thể thử sử dụng thuộc tính này với container thứ 2 để xem cách hoạt động. 😄

P/s: Thuộc tính background-size cũng có thể được sử dụng với một cặp giá trị chỉ Độ Dài. Giá trị đầu tiên sẽ là width (chiều rộng) và giá trị thứ 2 sẽ là height (chiều cao). Ví dụ: background-size: 500px 300px;

Thuộc tính background-position

Thông thường thì chúng ta sẽ muốn đảm bảo hình nền luôn che phủ hết diện tích của container. Vì vậy nên sẽ hay có một phần của hình nền bị ẩn đi. Thuộc tính background-position có thể giúp chúng ta thiết lập vị trí của hình nền để đảm bảo phần đẹp nhất của hình nền sẽ được hiển thị.

Đây là các giá trị mặc định của background-position:

background-position: left top;

Giá trị đầu tiên là vị trí theo phương ngang và có thể nhận một trong các khóa sau: left (bên trái), center (chính giữa), right (bên phải), hoặc một giá trị chỉ Độ Dài.

Giá trị thứ 2 là vị trí theo phương dọc và có thể nhận một trong các khóa sau: top (phía trên), center (chính giữa), bottom (phía dưới), hoặc một giá trị chỉ Độ Dài.

Hãy chỉnh sửa ví dụ trước đó của chúng ta một chút để xem background-position hoạt động như thế nào.

lovely.html

<!doctype html>
<html> <head> <meta charset="utf-8"> <title>Perfect Lovely Day</title> <link rel="stylesheet" href="lovely.css"> </head> <body> <section class="card bg-left-top"> <h2 class="card-msg">A perfect</h2> </section> <section class="card bg-center-top"> <h2 class="card-msg">lovely</h2> </section> <section class="card bg-right-top"> <h2 class="card-msg">daaay !</h2> </section> </body>
</html>

lovely.css

.card { display: inline-block; width: 224px; height: 378px; background-color: Crimson; background-image: url(https://i.imgur.com/sp2xQEy.png); background-size: cover;
} .card-msg { text-align: center; color: White;
} .bg-left-top { background-position: left top;
} .bg-center-top { background-position: center top;
} .bg-right-top { background-position: right top;
}

Bài viết về các thuộc tính background của chúng ta đến đây là kết thúc. Ngoài những thuộc tính mà chúng ta đã nói đến ở trên, CSS còn một vài thuộc tính khác nữa để làm việc với background mà mình đã không mang vào bài viết này. Đây là danh sách tất cả các thuộc tính background trong trường hợp bạn muốn tìm hiểu sâu hơn:

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 80

- 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 67

- 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 75

- 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