CSS: nth-child () CSS selector khớp với các phần tử dựa trên vị trí của chúng trong một nhóm anh chị em. hãy cùng W3seo tìm hiểu về selector này.
Giới thiệu về nth-child trong CSS
Trong CSS, nth-child
là một pseudo-class (lớp giả) được sử dụng để chọn và áp dụng các quy tắc cho các phần tử con của một phần tử cha dựa trên vị trí của chúng trong cây DOM. Pseudo-class nth-child
cho phép bạn chọn các phần tử con dựa trên thứ tự, vị trí, hoặc một công thức toán học.
Cú pháp sử dụng nth-child
như sau:
selector:nth-child(n)
Trong đó, selector
là bộ chọn CSS để chọn phần tử cha và n
là một giá trị số nguyên hoặc công thức toán học đại diện cho vị trí của phần tử con cần chọn.
Các ví dụ sử dụng cơ bản của nth-child
bao gồm:
- Chọn và áp dụng các quy tắc cho các phần tử con ở vị trí cụ thể, ví dụ:
p:nth-child(2)
sẽ chọn các phần tử<p>
ở vị trí thứ 2 trong phần tử cha. - Chọn và áp dụng các quy tắc cho các phần tử con theo công thức toán học, ví dụ:
div:nth-child(2n)
sẽ chọn các phần tử<div>
ở các vị trí chẵn trong phần tử cha. - Chọn và áp dụng các quy tắc cho các phần tử con từ vị trí x đến vị trí y, ví dụ:
li:nth-child(n+3):nth-child(-n+7)
sẽ chọn các phần tử<li>
từ vị trí thứ 3 đến vị trí thứ 7 trong phần tử cha.
nth-child
rất hữu ích trong việc tạo kiểu cho các phần tử con dựa trên vị trí của chúng trong cây DOM. Bằng cách sử dụng pseudo-class này, bạn có thể thay đổi màu sắc, font chữ, độ rộng, chiều cao và các thuộc tính khác của các phần tử con một cách linh hoạt.
Tuy nhiên, cần lưu ý rằng nth-child
đếm các phần tử con dựa trên tất cả các phần tử con trong phần tử cha, không chỉ các phần tử con cùng loại. Điều này có thể gây nhầm lẫn nếu bạn không đặt điều kiện chính xác.
Sử dụng nth-child
cùng với các pseudo-class khác như :first-child
, :last-child
, :nth-last-child
,… cho phép bạn thực hiện kiểu dáng và tùy chỉnh linh hoạt cho các phần tử con trong CSS.
Tóm lại, nth-child
là một pseudo-class quan trọng trong CSS giúp bạn lựa chọn và áp dụng các quy tắc cho các phần tử con dựa trên vị trí của chúng trong phần tử cha.
Xem thêm Từ khóa super trong Dart
Sử dụng nth-child để chọn phần tử
Để sử dụng pseudo-class nth-child
để chọn phần tử trong CSS, bạn có thể áp dụng nó vào bất kỳ phần tử nào mà bạn muốn chọn. Dưới đây là một số ví dụ sử dụng cơ bản của nth-child
:
- Chọn phần tử con ở vị trí cụ thể:
ul li:nth-child(2) { /* Áp dụng kiểu dáng cho phần tử li thứ 2 trong phần tử ul */ }
- Chọn phần tử con theo công thức toán học:
ul li:nth-child(odd) { /* Áp dụng kiểu dáng cho các phần tử li ở vị trí lẻ trong phần tử ul */ }
- Kết hợp với các lựa chọn khác:
ul li:nth-child(2n+1) { /* Áp dụng kiểu dáng cho các phần tử li ở vị trí lẻ trong phần tử ul */ }
- Chọn phần tử con trong một phần tử cha cụ thể:
.container div:nth-child(3) { /* Áp dụng kiểu dáng cho phần tử div thứ 3 trong phần tử có class .container */ }
Nhớ rằng nth-child
đếm tất cả các phần tử con trong phần tử cha, không chỉ các phần tử con cùng loại. Vì vậy, hãy đảm bảo bạn đặt các điều kiện chính xác để chọn đúng phần tử mà bạn muốn áp dụng kiểu dáng.
Bạn có thể thay đổi kiểu dáng, thuộc tính, màu sắc, hiển thị và các thuộc tính khác của các phần tử đã chọn bằng cách sử dụng nth-child
và các pseudo-class khác trong CSS.
Xem thêm Super Constructor trong ngôn ngữ Dart
Ví dụ nth-child
tr:nth-child(odd) or tr:nth-child(2n+1)
Đại diện cho các hàng lẻ của bảng HTML: 1, 3, 5, v.v.
tr:nth-child(even) or tr:nth-child(2n)
Đại diện cho các hàng chẵn của bảng HTML: 2, 4, 6, v.v.
:nth-child(7)
Đại diện cho phần tử thứ bảy.
:nth-child(5n)
Đại diện cho các phần tử 5 [= 5 × 1], 10 [= 5 × 2], 15 [= 5 × 3], v.v. Phần tử đầu tiên được trả về do kết quả của công thức là 0 [= 5×0], kết quả là không trùng khớp, vì các phần tử được lập chỉ mục từ 1, trong khi n bắt đầu từ 0. Điều này thoạt đầu có vẻ kỳ lạ, nhưng sẽ có ý nghĩa hơn khi phần B của công thức> 0, như trong ví dụ tiếp theo.
Xem thêm Từ khách hàng đến đại sứ thương hiệu
:nth-child(n+7)
Đại diện cho phần tử thứ bảy và tất cả các phần tử sau: 7 [= 0 + 7], 8 [= 1 + 7], 9 [= 2 + 7], v.v.
:nth-child(3n+4)
Đại diện cho các phần tử 4 [= (3 × 0) +4], 7 [= (3 × 1) +4], 10 [= (3 × 2) +4], 13 [= (3 × 3) +4], Vân vân.
:nth-child(-n+3)
Đại diện cho ba yếu tố đầu tiên. [= -0 + 3, -1 + 3, -2 + 3]
p:nth-child(n)
Đại diện cho mọi phần tử <p> trong một nhóm anh chị em. Điều này chọn các phần tử giống như một bộ chọn p đơn giản (mặc dù có độ đặc hiệu cao hơn).
p:nth-child(1) or p:nth-child(0n+1)
Đại diện cho mọi <p> là phần tử đầu tiên trong một nhóm anh chị em. Điều này giống với: bộ chọn con đầu tiên (và có cùng độ đặc hiệu).
p:nth-child(n+8):nth-child(-n+15)
Đại diện cho phần tử thứ tám đến mười lăm phần tử <p> của một nhóm anh chị em.
Ví dụ về :nth-child
See the Pen CSS-Tricks: :nth-child by Zachary Kain (@zakkain) on CodePen.
Xem thêm Dịch vụ tối ưu UX,UI
Các ứng dụng thực tế của nth-child
Pseudo-class nth-child
trong CSS rất hữu ích và có nhiều ứng dụng thực tế trong việc lựa chọn và áp dụng kiểu dáng cho các phần tử. Dưới đây là một số ví dụ về ứng dụng thực tế của nth-child
:
- Kiểu dáng các mục danh sách: Bạn có thể sử dụng
nth-child
để thiết lập kiểu dáng khác nhau cho các mục trong một danh sách. Ví dụ, bạn có thể làm cho các mục chẵn và lẻ có màu sắc hoặc nền khác nhau để tăng tính tương phản và tạo điểm nhấn. - Tạo bảng gạch đầu dòng: Bằng cách sử dụng
nth-child
, bạn có thể tạo hiệu ứng gạch đầu dòng cho các hàng trong bảng, giúp dễ đọc và tạo cấu trúc cho dữ liệu. - Xây dựng hệ thống lưới: Bạn có thể sử dụng
nth-child
để xây dựng hệ thống lưới linh hoạt, trong đó các phần tử con sẽ được sắp xếp và căn chỉnh một cách hợp lý trên trang web. - Kiểu dáng menu điều hướng: Khi bạn muốn thiết kế một menu điều hướng, bạn có thể sử dụng
nth-child
để thay đổi kiểu dáng của các liên kết hoặc mục menu khi chúng được chọn hoặc hover. - Hiển thị tin tức theo kiểu dáng khác nhau: Bạn có thể sử dụng
nth-child
để hiển thị các tin tức theo các kiểu dáng khác nhau trong một danh sách, ví dụ như làm nổi bật tin tức mới nhất hoặc thay đổi màu sắc của các tin tức trong quá khứ. - Kiểu dáng các slide trong carousel: Khi bạn xây dựng một carousel hoặc slide show, bạn có thể sử dụng
nth-child
để kiểm soát kiểu dáng của các slide, ví dụ như tạo hiệu ứng chuyển động hoặc áp dụng hiệu ứng hover cho các slide cụ thể.
Đây chỉ là một số ví dụ về cách sử dụng nth-child
trong các ứng dụng thực tế. Có rất nhiều cách bạn có thể sử dụng nth-child
để áp dụng kiểu dáng và tạo hiệu ứng trực quan trong CSS.
Xem thêm Method override trong Dart
Các lưu ý khi sử dụng nth-child
Khi sử dụng pseudo-class nth-child
trong CSS, có một số lưu ý quan trọng bạn nên nhớ:
- Đánh số phần tử từ 1: Lưu ý rằng các phần tử được đánh số từ 1, chứ không phải từ 0 như trong một số ngôn ngữ lập trình khác. Ví dụ,
:nth-child(1)
sẽ chọn phần tử đầu tiên,:nth-child(2)
sẽ chọn phần tử thứ hai, và cứ tiếp tục như vậy. - Chọn các phần tử con cùng loại:
nth-child
sẽ chọn tất cả các phần tử con trong phần tử cha, không chỉ các phần tử con cùng loại. Hãy đảm bảo bạn đã đặt các điều kiện chính xác để chọn đúng các phần tử mà bạn muốn áp dụng kiểu dáng. - Sử dụng công thức toán học: Bạn có thể sử dụng các công thức toán học để chọn các phần tử theo một mẫu nhất định. Ví dụ,
:nth-child(2n+1)
sẽ chọn tất cả các phần tử ở vị trí lẻ,:nth-child(3n)
sẽ chọn tất cả các phần tử ở vị trí chia hết cho 3, và cứ tiếp tục như vậy. - Sử dụng
:nth-of-type
nếu cần: Nếu bạn chỉ muốn chọn các phần tử con cùng loại trong phần tử cha, hãy sử dụng pseudo-class:nth-of-type
thay vìnth-child
.:nth-of-type
sẽ chọn các phần tử con cùng loại dựa trên vị trí của chúng trong phần tử cha. - Kiểm tra trình duyệt hỗ trợ:
nth-child
và:nth-of-type
được hỗ trợ bởi hầu hết các trình duyệt hiện đại. Tuy nhiên, trình duyệt cũ hơn có thể không hỗ trợ hoặc hỗ trợ không đầy đủ các pseudo-class này. Hãy kiểm tra trước để đảm bảo tính tương thích trên các trình duyệt mục tiêu của bạn. - Cân nhắc hiệu suất: Khi áp dụng
nth-child
cho các phần tử trong cây DOM lớn, nó có thể ảnh hưởng đến hiệu suất. Việc chọn các phần tử theonth-child
yêu cầu trình duyệt kiểm tra vị trí của tất cả các phần tử con, vì vậy hãy cân nhắc sử dụng nó trong các trường hợp cần thiết và hạn chế việc sử dụng nó cho các cây DOM phức tạp.
Nhớ những lưu ý này sẽ giúp bạn sử dụng nth-child
một cách chính xác và hiệu quả trong CSS.
Xem thêm Super trong java
Một số câu hỏi phổ biến về nth-child trong CSS
- nth-child là gì trong CSS? nth-child là một pseudoclass trong CSS, nó được sử dụng để chọn phần tử con thứ n trong phần tử cha của nó. Nó cũng có thể được sử dụng để chọn phần tử con của một loại cụ thể trong phần tử cha.
- Cú pháp của nth-child là gì? nth-child được viết dưới dạng :nth-child(an+b), trong đó a và b là các số nguyên không âm. Ví dụ:
- :nth-child(2) chọn phần tử con thứ hai của phần tử cha.
- :nth-child(odd) chọn tất cả các phần tử con lẻ của phần tử cha.
- :nth-child(even) chọn tất cả các phần tử con chẵn của phần tử cha.
- nth-child(n) và nth-of-type(n) khác nhau như thế nào? nth-child(n) chọn tất cả các phần tử con của phần tử cha theo vị trí của chúng. Tuy nhiên, nth-of-type(n) chỉ chọn các phần tử con của phần tử cha theo loại của chúng. Ví dụ: nth-child(3) sẽ chọn phần tử con thứ ba bất kỳ loại phần tử con nào, trong khi nth-of-type(3) chỉ chọn phần tử con thứ ba cùng loại với phần tử cha.
- Nth-child có thể được sử dụng để thực hiện những gì? Nth-child có thể được sử dụng để:
- Chọn tất cả các phần tử con của một phần tử cha.
- Chọn các phần tử con theo vị trí của chúng trong phần tử cha.
- Chọn các phần tử con theo kiểu của chúng trong phần tử cha.
- Chọn các phần tử con với một số kết hợp các giá trị a và b.
- Nth-child có hỗ trợ cho tất cả các trình duyệt không? Nth-child được hỗ trợ trên tất cả các trình duyệt hiện đại, bao gồm cả Internet Explorer 9 trở lên. Tuy nhiên, các phiên bản trình duyệt cũ hơn có thể không hỗ trợ pseudoclass này.
- Làm thế nào để sử dụng nth-child để chọn phần tử con? Để sử dụng nth-child để chọn phần tử con, bạn cần chỉ định các giá trị a và b vào trong pseudoclass. Ví dụ:
- Chọn tất cả các phần tử con thứ ba trong phần tử cha:
:nth-child(3)
- Chọn tất cả các phần tử con thứ chẵn trong phần tử cha:
:nth-child(even)
- Chọn tất cả các phần tử con thứ lẻ trong phần tử cha:
:nth-child(odd)
- Chọn tất cả các phần tử con thứ 2, 3, 4, 5, 6 trong phần tử cha:
:nth-child(n+2):nth-child(-n+6)
- Làm thế nào để sử dụng nth-child để chọn phần tử con theo loại của chúng? Để sử dụng nth-child để chọn phần tử con theo loại của chúng, bạn cần sử dụng nth-of-type pseudoclass. Ví dụ:
- Chọn tất cả các phần tử con thứ ba của loại div trong phần tử cha:
div:nth-of-type(3)
- Chọn tất cả các phần tử con thứ lẻ của loại p trong phần tử cha:
p:nth-of-type(odd)
- Chọn tất cả các phần tử con thứ chẵn của loại ul trong phần tử cha:
ul:nth-of-type(even)
- Làm thế nào để sử dụng nth-child để chọn phần tử con theo các giá trị kết hợp a và b? Để sử dụng nth-child để chọn phần tử con theo các giá trị kết hợp a và b, bạn cần sử dụng công thức an+b trong pseudoclass. Ví dụ:
- Chọn tất cả các phần tử con thứ 4, 7, 10, 13, 16, … trong phần tử cha:
:nth-child(3n+1)
- Chọn tất cả các phần tử con thứ 3, 5, 7, 9, 11, … trong phần tử cha:
:nth-child(2n+1)
- Chọn tất cả các phần tử con thứ 2, 5, 8, 11, 14, … trong phần tử cha:
:nth-child(3n-1)
- Có thể sử dụng nth-child để chọn phần tử con dựa trên trạng thái của chúng không? Không, bạn không thể sử dụng nth-child để chọn phần tử con dựa trên trạng thái của chúng, ví dụ như khi chúng được checked hay focus. Để chọn phần tử con dựa trên trạng thái của chúng, bạn cần sử dụng pseudoclass khác như :checked hoặc :focus.
- Có bao nhiêu giá trị có thể được sử dụng trong pseudoclass nth-child? Bạn có thể sử dụng bất kỳ giá trị nguyên dương nào trong pseudoclass nth-child, bao gồm 1, 2, 3, 4, 5, … Ngoài ra, bạn cũng có thể sử dụng từ khóa even và odd để chọn các phần tử con thứ chẵn hoặc lẻ.
- Có thể sử dụng nth-child để chọn tất cả các phần tử con trừ phần tử con đầu tiên hoặc cuối cùng không? Có, bạn có thể sử dụng nth-child để chọn tất cả các phần tử con trừ phần tử con đầu tiên hoặc cuối cùng bằng cách sử dụng pseudoclass :not và kết hợp với nth-child. Ví dụ:
- Chọn tất cả các phần tử con trừ phần tử con đầu tiên của phần tử cha:
:not(:first-child)
- Chọn tất cả các phần tử con trừ phần tử con cuối cùng của phần tử cha:
:not(:last-child)