Chỉ mục Z và ngữ cảnh xếp chồng

Giả sử bạn có một vài yếu tố được định vị tuyệt đối, và phải được đặt chồng lên nhau. Bạn có thể viết một chút về HTML như sau:

<div class="stacked-items">
    <div class="item-1">Item 1</div>
    <div class="item-2">Item 2</div>
</div>

Nhưng theo mặc định, cái nào sẽ xếp chồng lên nhau? Để biết mục nào sẽ làm việc đó, bạn cần hiểu ngữ cảnh chỉ mục z và bối cảnh xếp chồng.

Chỉ mục Z

z-index đặt thứ tự lớp cho HTML một cách rõ ràng dựa trên không gian 3D của trình duyệt — trục Z. Đây là trục cho biết lớp nào ở gần và xa bạn hơn. Trục tung trên web là trục Y và trục hoành là trục X.

Mỗi trục bao quanh phần tử

Thuộc tính z-index chấp nhận một giá trị số có thể là số dương hoặc số âm. Các phần tử sẽ xuất hiện phía trên một phần tử khác nếu có giá trị z-index cao hơn. Nếu bạn không đặt z-index trong các phần tử thì hành vi mặc định là thứ tự nguồn tài liệu sẽ quy định trục Z. Điều này có nghĩa là các phần tử ở phía dưới tài liệu sẽ nằm phía trên các phần tử xuất hiện trước chúng.

Trong luồng bình thường, nếu bạn đặt một giá trị cụ thể cho z-index nhưng giá trị này không hoạt động, bạn cần đặt giá trị position của phần tử thành bất kỳ giá trị nào khác ngoài static. Đây là địa điểm thường gặp khi mọi người gặp vấn đề với z-index.

Điều này không đúng nếu bạn đang ở trong bối cảnh hộp linh hoạt hoặc lưới vì bạn có thể sửa đổi z-index của các mục linh hoạt hoặc lưới mà không cần thêm position: relative.

Chỉ mục z âm

Để đặt một phần tử phía sau một phần tử khác, hãy thêm một giá trị âm cho z-index.

.my-element {
    background: rgb(232 240 254 / 0.4);
}

.my-element .child {
    position: relative;
    z-index: -1;
}

Miễn là .my-element có giá trị ban đầu là z-indexauto, thì phần tử .child sẽ nằm phía sau.

Thêm CSS sau vào .my-element, và phần tử .child sẽ không nằm phía sau.

.my-element {
  position: relative;
  z-index: 0;
  background: rgb(232 240 254 / 0.4);
}

Bởi vì .my-element hiện có giá trị position không phải là static và giá trị z-index không phải là auto, thao tác này đã tạo ra một ngữ cảnh xếp chồng mới. Điều này có nghĩa là ngay cả khi bạn đặt .childz-index-999, thì nó vẫn sẽ không nằm phía sau .my-parent.

Ngữ cảnh xếp chồng

Ngữ cảnh xếp chồng là một nhóm các phần tử có một thành phần mẹ chung và cùng nhau di chuyển lên và xuống trục z.

Trong ví dụ này, phần tử mẹ đầu tiên có z-index1, để tạo một ngữ cảnh xếp chồng mới. Phần tử con của thành phần này có z-index999. Bên cạnh phần tử mẹ này, có một phần tử mẹ khác có một phần tử con. Phần tử mẹ có z-index2 và phần tử con cũng có z-index2. Vì cả hai phần tử mẹ đều tạo ngữ cảnh xếp chồng, z-index của tất cả phần tử con dựa trên giá trị của phần tử mẹ.

z-index của các phần tử bên trong ngữ cảnh xếp chồng luôn tương ứng với thứ tự hiện tại của thành phần mẹ trong ngữ cảnh xếp chồng riêng.

Tạo ngữ cảnh xếp chồng

Bạn không cần áp dụng z-indexposition để tạo một mã mới ngữ cảnh xếp chồng. Bạn có thể tạo ngữ cảnh xếp chồng mới bằng cách thêm giá trị cho các thuộc tính tạo lớp tổng hợp mới chẳng hạn như opacity, will-changetransform. Bạn có thể xem danh sách đầy đủ các cơ sở lưu trú tại đây.

Để giải thích lớp tổng hợp là gì, hãy tưởng tượng một trang web là một canvas. Trình duyệt sẽ lấy HTML và CSS của bạn rồi sử dụng chúng để xác định kích thước của canvas. Sau đó, trang sẽ được vẽ trên canvas này. Nếu một phần tử cần thay đổi, chẳng hạn như nó thay đổi vị trí—trình duyệt sau đó phải quay lại và tìm ra nội dung cần vẽ.

Để giúp cải thiện hiệu suất, trình duyệt sẽ tạo các lớp tổng hợp mới được xếp chồng lên trên canvas. Các tính năng này khá giống với ghi chú sau khi tạo: việc di chuyển xung quanh và thay đổi không ảnh hưởng lớn đến canvas tổng thể. Một lớp tổng hợp mới được tạo cho các phần tử có opacity, transformwill-change vì những chỉ số này rất có khả năng thay đổi, để trình duyệt đảm bảo rằng thay đổi có hiệu suất tốt nhất có thể bằng cách sử dụng GPU để áp dụng các điều chỉnh kiểu.

Tài nguyên

Kiểm tra kiến thức

Kiểm tra kiến thức của bạn về chỉ mục z

<section>
  <article>1</article>
  <article>2</article>
  <article>3</article>
  <article>4</article>
</section>

Bài viết nào ở trên cùng theo mặc định?

2
3
4
1

Nếu chỉ mục z không hoạt động, bạn nên kiểm tra thuộc tính nào trên phần tử của mình?

relative
animation
position
display

Hộp linh hoạt và lưới có cần position: relative không?

Không