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

Khám phá thuộc tính Masonry của CSS Grid: Tối ưu hóa sắp xếp các phần tử trên website

0 0 16

Người đăng: Hoàng Quang

Theo Viblo Asia

CSS Grid đã mang lại một cuộc cách mạng trong việc thiết kế giao diện web, cung cấp cho các nhà phát triển nhiều cách linh hoạt hơn để kiểm soát cách các phần tử được sắp xếp trên trang. Trong số những tính năng độc đáo của CSS Grid, thuộc tính Masonry đã thu hút sự chú ý đặc biệt từ cộng đồng phát triển web. Thuộc tính này mang lại khả năng tạo ra các bố cục "masonry-style", trong đó các phần tử được xếp chồng lên nhau một cách tự động và một cách hợp lý, tạo ra một cảm giác tự nhiên và hấp dẫn.

Định nghĩa của thuộc tính Masonry

Thuộc tính Masonry của CSS Grid cung cấp cho các nhà phát triển khả năng tạo ra các bố cục masonry-style, giống như kiểu sắp xếp mà bạn thường thấy trong các bảng tin xã hội hoặc trang web trình bày hình ảnh. Sự khác biệt lớn nhất giữa Masonry và các phương pháp sắp xếp truyền thống khác là các cột không cố định về chiều cao. Thay vào đó, các phần tử sẽ tự động xếp chồng lên nhau, tận dụng không gian trống một cách tối ưu để tạo ra một bố cục linh hoạt và hiệu quả.

Lợi ích của Masonry

  1. Sắp xếp tự động: Masonry tự động điều chỉnh các phần tử để xếp chồng chúng lên nhau một cách hợp lý, không cần phải định rõ kích thước hoặc vị trí cụ thể cho mỗi phần tử.

  2. Tối ưu hóa không gian: Bằng cách xếp chồng các phần tử một cách tự nhiên và hợp lý, Masonry giúp tối ưu hóa không gian trống trên trang, giúp trang web của bạn trở nên gọn gàng và hiệu quả hơn.

  3. Khả năng tương thích: Thuộc tính Masonry cũng hoạt động tốt trên các thiết bị di động và được thiết kế để phản ứng linh hoạt với các kích thước màn hình khác nhau, giúp cải thiện trải nghiệm người dùng trên các thiết bị di động.

  4. Dễ dàng thích ứng: Với sức mạnh của CSS Grid, bạn có thể dễ dàng thay đổi số lượng cột và các thuộc tính khác của Masonry để phù hợp với nhu cầu cụ thể của trang web bạn.

Sử dụng Masonry trong CSS Grid

Để sử dụng Masonry trong CSS Grid, bạn xem qua ví dụ bên dưới

  1. Tạo HTML
<div class="container"> <div><img src="https://i.pinimg.com/474x/53/e2/ee/53e2ee84f7871f03d35a506d88ae0f1e.jpg"></div> <div><img src="https://i.pinimg.com/474x/e8/0d/50/e80d5005c675fe6e30bdd886c44f4034.jpg"></div> <div><img src="https://i.pinimg.com/474x/c9/08/fd/c908fd008289491ee6f8505e18feb88e.jpg"></div> <div><img src="https://i.pinimg.com/474x/da/48/b5/da48b5d766c611e2850f58f7f008542a.jpg"></div> <div><img src="https://i.pinimg.com/474x/86/8a/63/868a6309b12210ddd1518b9d5b3732fc.jpg"></div> <div><img src="https://i.pinimg.com/474x/9e/64/51/9e6451015ac9bdfe51de4e933bb12209.jpg"></div> <div><img src="https://i.pinimg.com/474x/07/4c/37/074c377726c0b74d9bcdab87a93edf8f.jpg"></div> <div><img src="https://i.pinimg.com/474x/92/56/ab/9256ab0bc2bd6109cd4c26e0cf0030d7.jpg"></div> <div><img src="https://i.pinimg.com/474x/16/5e/96/165e96e6dcafc2085c01937b8b8b6f03.jpg"></div> <div><img src="https://i.pinimg.com/474x/a2/91/86/a29186836e874b94c2a70c1ce7d6277e.jpg"></div> <div><img src="https://i.pinimg.com/474x/af/d8/c4/afd8c469530740ef37ed744396c1d662.jpg"></div> <div><img src="https://i.pinimg.com/474x/9c/4f/30/9c4f3022188ed2d798ecca6fc0a5840c.jpg"></div>
</div>
  1. Viết CSS
.container { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 16px; grid-template-rows: masonry;
} .container > div > img { width: 100%; border-radius: 16px;
}

Trong đó, auto-fill cho phép các cột tự động điều chỉnh để lấp đầy không gian mẹ container, minmax() xác định kích thước tối thiểu và tối đa cho mỗi cột, gap thiết lập khoảng cách giữa các phần tử, và grid-template-rows giúp hiển thị các phần tử ở chế độ masonry.

  1. Xem kết quả

Kết luận

Thuộc tính Masonry của CSS Grid là một công cụ mạnh mẽ cho việc tạo ra các bố cục linh hoạt và hiệu quả cho trang web của bạn. Với khả năng tự động sắp xếp các phần tử một cách tự nhiên và hợp lý, Masonry không chỉ giúp tối ưu hóa không gian trống mà còn cải thiện trải nghiệm người dùng. Hãy khám phá và áp dụng Masonry trong dự án của bạn để tạo ra các trải nghiệm web độc đáo và hấp dẫn.

Bình luận

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

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

Một số quy tắc và name class phổ biến cho Front-end Dev

Trong CSS, các thủ tục setting đóng vai trò to lớn, nhưng bên cạnh đó, cách đặt tên theo các từ đơn sao cho phù hợp cũng quan trọng không kém . Đặt tên rất khó, nhưng cũng rất quan trọng .

0 0 93

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

2021, chúng ta cần tối ưu hóa việc tải hình ảnh trên web như nào?

Rất chào các bạn,. Như các bạn đã biết, trong kỉ nguyên công nghệ, song song với sự sinh ra dày đặc của các trang web mới cũng là sự biến mất của những trang web "lạc hậu" hay hoạt động kém hiệu quả.

0 0 57

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

Tài nguyên nghiên cứu sâu Html

1. Articles and standards. . HTML 5.

0 0 198

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

Tìm hiểu về Event.preventDefault(), Event.stopPropagation() và Event.stopImmediatePropagation()

Chúng ta thương thấy 3 method này và có thể dẫn dến bối rối và nhầm lẫn giữa chúng:. . Event.preventDefault().

0 0 52

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

Vanilla JS Project: Tính tuổi

1. Yêu cầu.

0 0 74

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

Thủ thuật nhỏ để căn chỉnh image với object-fit

Chào các bạn,. Có lẽ trong hành trình code của các bạn thì không ít lần gặp vấn đề méo ảnh do fix cứng cả width, height của ảnh nhỉ? Hoặc kể cả khi bạn set value cho 1 thuộc tính weigth hoặc height còn thuộc tính còn lại để auto thì nhiều lúc ảnh cũng không được hiển thị toàn vẹn cho lắm.

0 0 49