The CSS Podcast – 018: Tiêu điểm
Trên trang web, bạn nhấp vào một đường liên kết để chuyển người dùng đến nội dung chính của trang web. Những đường liên kết này thường được gọi là đường liên kết bỏ qua hoặc đường liên kết neo. Khi liên kết đó được kích hoạt bằng bàn phím, sử dụng phím tab và enter, vùng chứa nội dung chính sẽ có vòng tròn tiêu điểm xung quanh. Tại sao lại như vậy?
Lý do là <main>
có giá trị thuộc tính tabindex="-1"
, nghĩa là có thể được lấy tiêu điểm theo phương thức lập trình.
Khi <main>
được nhắm mục tiêu (vì #main-content
trong thanh URL của trình duyệt khớp với id
), thành phần này sẽ nhận được tiêu điểm có lập trình.
Bạn có thể muốn xoá các kiểu tiêu điểm trong những trường hợp này, nhưng việc xử lý tiêu điểm một cách thích hợp và cẩn thận sẽ giúp tạo ra trải nghiệm người dùng tốt, dễ tiếp cận.
Đây cũng có thể là một nơi tuyệt vời để thêm một số điểm thú vị vào các hoạt động tương tác.
Tại sao tiêu điểm lại quan trọng?
Là một nhà phát triển web, bạn cần phải tạo ra một trang web dễ tiếp cận và phù hợp với tất cả mọi người. Việc tạo trạng thái tâm điểm hỗ trợ tiếp cận bằng CSS là một phần trong trách nhiệm này.
Kiểu tiêu điểm hỗ trợ những người sử dụng thiết bị như bàn phím hoặc công tắc điều khiển để di chuyển và tương tác với trang web. Nếu một phần tử nhận được tiêu điểm và không có chỉ báo trực quan, người dùng có thể mất dấu những gì đang được lấy tiêu điểm. Điều này có thể gây ra vấn đề điều hướng và dẫn đến hành vi không mong muốn nếu người dùng truy cập vào đường liên kết không chính xác.
Cách các phần tử nhận được tiêu điểm
Một số phần tử nhất định sẽ tự động có thể lấy tiêu điểm; đây là những phần tử chấp nhận tương tác và nhập, chẳng hạn như <a>
, <button>
, <input>
và <select>
.
Tóm lại, tất cả các phần tử biểu mẫu, nút và đường liên kết.
Thông thường, bạn có thể điều hướng các phần tử có thể làm tâm điểm của trang web bằng cách sử dụng phím tab để di chuyển về phía trước trên trang và shift + tab để di chuyển về phía sau.
Ngoài ra, còn có một thuộc tính HTML có tên là tabindex
cho phép bạn thay đổi chỉ mục thẻ – thứ tự các phần tử được lấy tiêu điểm – mỗi khi người dùng nhấn phím tab hoặc tiêu điểm được chuyển đổi bằng một thay đổi về hàm băm trong URL hoặc bằng một sự kiện JavaScript.
Nếu tabindex
trên một phần tử HTML được đặt thành 0
, thì phần tử này có thể nhận tiêu điểm thông qua phím tab và sẽ tuân theo chỉ mục thẻ chung, được xác định theo thứ tự nguồn tài liệu.
Nếu bạn đặt tabindex
thành -1
, thì thành phần này chỉ có thể nhận tiêu điểm theo phương thức lập trình, nghĩa là chỉ khi một sự kiện JavaScript xảy ra hoặc một thay đổi về hàm băm (khớp với id
của phần tử trong URL) xảy ra.
Nếu bạn đặt tabindex
thành bất kỳ giá trị nào cao hơn 0
, thì giá trị này sẽ bị xoá khỏi chỉ mục thẻ toàn cục, được xác định theo thứ tự nguồn tài liệu.
Trình tự nhấn phím Tab hiện sẽ được xác định theo giá trị của tabindex
, vì vậy, một phần tử có tabindex="1"
sẽ nhận được tiêu điểm trước một phần tử có tabindex="2"
, chẳng hạn.
Tiêu điểm tạo kiểu
Hành vi mặc định của trình duyệt khi một phần tử nhận được tiêu điểm là hiển thị một vòng tròn tiêu điểm. Vòng tiêu điểm này khác nhau giữa trình duyệt và hệ điều hành.
Bạn có thể thay đổi hành vi này bằng CSS, sử dụng các lớp giả :focus
, :focus-within
và :focus-visible
mà bạn đã tìm hiểu trong bài học về lớp giả.
Điều quan trọng là bạn phải đặt kiểu tiêu điểm có độ tương phản với kiểu mặc định của một phần tử.
Ví dụ: một phương pháp phổ biến là sử dụng thuộc tính outline
.
a:focus {
outline: 2px solid slateblue;
}
Thuộc tính outline
có thể xuất hiện quá gần văn bản của đường liên kết, nhưng thuộc tính outline-offset
có thể giúp giải quyết vấn đề này, vì thuộc tính này thêm padding
hình ảnh bổ sung mà không ảnh hưởng đến kích thước hình học mà phần tử lấp đầy.
Giá trị số dương cho outline-offset
sẽ đẩy đường viền ra ngoài, còn giá trị âm sẽ kéo đường viền vào trong.
Hiện tại, trong một số trình duyệt, nếu bạn đặt border-radius
trên phần tử và sử dụng outline
, thì phần tử này sẽ không khớp – đường viền sẽ có các góc nhọn.
Do đó, bạn nên sử dụng box-shadow
có bán kính làm mờ nhỏ vì box-shadow
sẽ cắt theo hình dạng, tuân theo border-radius
, nhưng kiểu này sẽ không hiển thị ở Chế độ tương phản cao của Windows.
Điều này là do Chế độ tương phản cao của Windows không áp dụng bóng và chủ yếu bỏ qua hình nền để ưu tiên chế độ cài đặt mà người dùng ưu tiên.
Tóm tắt
Việc tạo trạng thái tiêu điểm tương phản với trạng thái mặc định của một phần tử là vô cùng quan trọng. Các kiểu trình duyệt mặc định đã thực hiện việc này cho bạn, nhưng nếu bạn muốn thay đổi hành vi này, hãy nhớ những điều sau:
- Tránh sử dụng
outline: none
trên một phần tử có thể nhận tiêu điểm bàn phím. - Tránh thay thế kiểu
outline
bằngbox-shadow
. vì chúng không xuất hiện trong Chế độ tương phản cao của Windows. - Chỉ đặt giá trị dương cho
tabindex
trên phần tử HTML nếu bạn thực sự cần. - Đảm bảo trạng thái lấy nét rất rõ ràng so với trạng thái mặc định.
Kiểm tra mức độ hiểu biết
Kiểm tra kiến thức của bạn về tiêu điểm
Mục nào sau đây là thành phần có thể tự động lấy tiêu điểm?
<a>
<p>
<button>
<input>
<output>
<select>
Thiết bị đầu vào nào sau đây có thể đặt tiêu điểm?