Images

Hình ảnh trang trí, chẳng hạn như màu chuyển tiếp trên các nút hoặc hình nền trên các phần nội dung hoặc toàn bộ trang, mang tính trình bày và cần được áp dụng cùng với CSS. Khi một hình ảnh bổ sung bối cảnh cho tài liệu, thì hình ảnh đó chính là nội dung và nên được được nhúng bằng HTML.

Phương thức chính để thêm hình ảnh là thẻ <img>src tham chiếu đến một tài nguyên hình ảnh và thuộc tính alt mô tả hình ảnh.

<img src="images/eve.png" alt="Eve">

Cả thuộc tính srcset trên <img> và phần tử <picture> đều cung cấp cách thêm nhiều nguồn hình ảnh có các truy vấn phương tiện được liên kết, mỗi truy vấn có một nguồn hình ảnh dự phòng, cho phép phân phối tệp hình ảnh thích hợp nhất dựa trên độ phân giải, khả năng của trình duyệt và kích thước khung nhìn. Thuộc tính srcset cho phép cung cấp nhiều phiên bản hình ảnh dựa trên độ phân giải và kích thước khung nhìn của trình duyệt cùng thuộc tính sizes.

<img src="images/eve.png" alt="Eve"
  srcset="images/eve.png 400w, images/eve-xl.jpg 800w"
  sizes="(max-width: 800px) 400px, 800px" />

Bạn cũng có thể thực hiện việc này với phần tử <picture> cùng với phần tử con <source>. Phần tử này sẽ lấy <img> làm nguồn mặc định.

<picture>
  <source src="images/eve.png" media="(max-width: 800px)" />
  <source src="images/eve-xl.jpg" />
  <img src="images/eve.png" alt="Eve" />
</picture>

Ngoài các phương pháp hình ảnh đáp ứng HTML tích hợp sẵn này, HTML cũng cho phép hiển thị hình ảnh hiệu suất kết xuất được cải thiện thông qua nhiều thuộc tính. Thẻ <img> và do đó, các nút gửi dạng đồ hoạ <input type="image">, có thể bao gồm thuộc tính heightwidth để đặt tỷ lệ khung hình của hình ảnh nhằm giảm sự thay đổi bố cục nội dung. Thuộc tính lazy cho phép tải từng phần.

HTML cũng hỗ trợ việc bao gồm hình ảnh SVG bằng cách sử dụng trực tiếp <svg>, mặc dù SVG Bạn có thể nhúng hình ảnh có phần mở rộng .svg (hoặc dưới dạng data-uri) bằng phần tử <img>.

Tối thiểu, mỗi hình ảnh nền trước phải bao gồm thuộc tính srcalt.

Tệp src là đường dẫn và tên tệp của hình ảnh được nhúng. Thuộc tính src dùng để cung cấp URL cho hình ảnh. Sau đó, trình duyệt sẽ tìm nạp thành phần và kết xuất thành phần đó lên trang. Thuộc tính này là bắt buộc theo <img>; nếu không có thì sẽ chẳng có gì để kết xuất.

Thuộc tính alt cung cấp văn bản thay thế cho hình ảnh, cung cấp nội dung mô tả hình ảnh cho những người không xem được màn hình (chẳng hạn như các công cụ tìm kiếm và công nghệ hỗ trợ, cũng như thậm chí cả Alexa, Siri và Trợ lý Google) và có thể được trình duyệt hiển thị nếu hình ảnh không tải. Ngoài những người dùng có mạng chậm hoặc băng thông giới hạn, văn bản alt cực kỳ hữu ích trong HTML email, vì nhiều người dùng chặn hình ảnh trong các ứng dụng email của họ.

<img src="path/filename" alt="descriptive text" />

Nếu hình ảnh đó thuộc loại tệp SVG, bạn cũng nên bao gồm role="img". do lỗi VoiceOver do lỗi.

<img src="switch.svg" alt="light switch" role="img" />

Đang viết nội dung mô tả hình ảnh alt hiệu quả

Thuộc tính thay thế cần phải ngắn gọn và súc tích, cung cấp tất cả thông tin liên quan mà hình ảnh truyền tải dù bỏ qua thông tin thừa cho nội dung khác trong tài liệu hoặc không hữu ích. Khi viết văn bản, giọng điệu nên phản ánh tông điệu của trang web.

Để viết văn bản thay thế hiệu quả, hãy tưởng tượng rằng bạn đang đọc toàn bộ trang cho một người không xem được. Bằng cách sử dụng phần tử <img> ngữ nghĩa, người dùng và bot của trình đọc màn hình sẽ được thông báo phần tử đó là một hình ảnh. Không cần phải thêm dòng chữ "Đây là hình ảnh/ảnh chụp màn hình/ảnh chụp" trong alt. Người dùng không cần biết có hình ảnh, nhưng họ lại cần biết thông tin mà hình ảnh truyền tải.

Thông thường, bạn sẽ không nói: "Đây là hình ảnh sần sùi của một chú chó đội mũ màu đỏ". Thay vào đó, bạn sẽ chuyển tiếp thông tin về hình ảnh truyền đạt theo ngữ cảnh của phần còn lại của tài liệu; và nội dung bạn truyền tải sẽ thay đổi tuỳ theo bối cảnh và nội dung của văn bản xung quanh.

Ví dụ: hình ảnh một chú chó sẽ được mô tả theo nhiều cách, tùy thuộc vào bối cảnh. Nếu Fluffy là hình đại diện bên cạnh đánh giá thức ăn cho chó Yuckymeat, alt="Fluffy" đủ.

Nếu bức ảnh là một phần trang nhận nuôi của Fluffy trên một trang web của một trung tâm cứu trợ động vật, thì đối tượng mục tiêu là chú chó tương lai cha mẹ. Văn bản phải mô tả thông tin được truyền tải trong ảnh phù hợp với người sử dụng và không bị trùng lặp trong văn bản xung quanh. Bạn nên sử dụng nội dung mô tả dài hơn, chẳng hạn như alt="Fluffy, a tri-color terrier with very short hair, with a tennis ball in her mouth". Văn bản của trang nhận nuôi thường bao gồm loài, giống, tuổi và giới tính của thú cưng được nhận nuôi, nên bạn không cần lặp lại điều này trong văn bản thay thế. Nhưng tiểu sử được viết của chú chó có thể không bao gồm chiều dài tóc, màu sắc hoặc sở thích về đồ chơi. Xin lưu ý rằng chúng tôi không mô tả hình ảnh này: người nuôi chó tương lai không cần biết liệu chú chó có phải trong nhà hoặc ngoài trời hoặc có vòng cổ màu đỏ và dây xích màu xanh dương.

Khi sử dụng hình ảnh cho hình tượng học, vì thuộc tính alt cung cấp tên thành phần hỗ trợ tiếp cận, hãy truyền tải ý nghĩa của biểu tượng, không phải mô tả hình ảnh. Ví dụ: thuộc tính alt của biểu tượng kính lúp là search. Biểu tượng trông chẳng hạn như một ngôi nhà có home làm văn bản thay thế. Nội dung mô tả của biểu tượng đĩa mềm 5 inch là save. Nếu có hai biểu tượng Fluffy được sử dụng để biểu thị các phương pháp hay nhất và các hoạ tiết phản cảm, chú chó đội mũ nồi màu xanh lục có thể mỉm cười, còn chú chó gầm gừ đang mặc alt="good" trên chiếc mũ nồi màu đỏ có thể đọc là alt="bad". Điều đó có nghĩa là chỉ sử dụng biểu tượng chuẩn và nếu bạn sử dụng các biểu tượng không chuẩn, chẳng hạn như Fluffy tốt và không tốt, hãy thêm chú thích và đảm bảo rằng các biểu tượng không phải là cách duy nhất để giải mã ý nghĩa của các thành phần trên giao diện người dùng,

Nếu hình ảnh là ảnh chụp màn hình hoặc biểu đồ, hãy viết những gì học được từ hình ảnh thay vì mô tả hình dáng. Mặc dù một hình ảnh chắc chắn đáng giá cả nghìn từ nhưng phần mô tả phải truyền tải súc tích mọi kiến thức học được.

Bỏ qua thông tin mà người dùng đã biết từ bối cảnh và được cung cấp thông tin khác trong nội dung. Ví dụ: nếu bạn đang xem trang hướng dẫn về cách thay đổi chế độ cài đặt trình duyệt và trang này hướng dẫn cách nhấp vào các biểu tượng trong trình duyệt Chrome, thì URL của trang trong ảnh chụp màn hình không quan trọng. Giới hạn alt ở chủ đề có sẵn: cách thay đổi chế độ cài đặt. alt có thể là "Biểu tượng cài đặt nằm trong thanh điều hướng bên dưới trường tìm kiếm." Đừng thêm "ảnh chụp màn hình" hoặc "máy học máy" vì người dùng không cần biết đó là ảnh chụp màn hình và không cần biết kỹ thuật viên đang lướt web ở đâu khi họ viết các hướng dẫn. Nội dung mô tả hình ảnh dựa trên ngữ cảnh của lý do hình ảnh đó được đưa vào địa điểm đầu tiên.

Nếu ảnh chụp màn hình hiển thị cách tìm số phiên bản trình duyệt bằng cách truy cập vào chrome://version/, hãy thêm URL vào nội dung của trang làm hướng dẫn và cung cấp một chuỗi trống làm thuộc tính alt vì hình ảnh không cung cấp thông tin không có trong văn bản xung quanh.

Nếu hình ảnh không cung cấp thêm thông tin hoặc chỉ mang tính chất trang trí, thì thuộc tính vẫn nên ở đó, chỉ dưới dạng một chuỗi trống.

<img src="svg/magazine.svg" alt="" role="none" />

Machine LearningShop.com có 7 hình ảnh nền trước, do đó, 7 hình ảnh có thuộc tính alt: công tắc đèn trứng phục sinh, một biểu tượng thủ công, hai ảnh tiểu sử của Hal và Eve cùng ba hình đại diện của một máy xay, một máy hút bụi và một máy nướng bánh mì. Chiến lược phát hành đĩa đơn hình ảnh nền trước trông giống như một tạp chí là hình ảnh duy nhất chỉ mang tính chất trang trí. Trang này cũng có hai hình nền; những hình ảnh này cũng mang tính chất trang trí và không thể truy cập được khi được thêm bằng CSS.

Tạp chí chỉ mang tính chất trang trí, có thuộc tính alt trống và role của none vì hình ảnh chỉ mang tính chất trang trí SVG trình chiếu. Nếu có ý nghĩa, hình ảnh SVG phải bao gồm role="img".

<img src="svg/magazine.svg" alt="" role="none" />

Có ba bài đánh giá ở cuối trang, mỗi bài đánh giá có một hình ảnh của áp phích. Thông thường, văn bản alt là tên của người trong ảnh.

<img src="images/blender.svg" alt="Blendan Smooth" role="img" />

Do đây là trang đùa nên bạn nên truyền tải những gì có thể không rõ ràng đối với người dùng có thị lực kém để họ không bỏ lỡ hài hước; chúng tôi sẽ sử dụng hàm máy gốc làm alt thay vì sử dụng tên của ký tự:

<img src="images/blender.svg" alt="blender" role="img" />

Ảnh của người hướng dẫn không chỉ là ảnh đại diện: chúng là ảnh tiểu sử và do đó được mô tả chi tiết hơn.

Nếu đây là một trang web có thật, bạn sẽ chỉ cung cấp nội dung mô tả tối thiểu về diện mạo của giáo viên để một học sinh tương lai có thể nhận ra các em khi bước vào lớp học.

<img src="svg/hal.svg" role="img"
  alt="Hal 9000; a camera lens containing a red dot that sometimes changes to yellow." />

Vì đây là trang web chuyện cười, hãy cung cấp thông tin có liên quan trong ngữ cảnh trò đùa:

<img src="svg/hal.svg" role="img"
  alt="Hal 9000, the sentient AI computer from 2001: a Space Odyssey depicted as a camera lens with a red dot that changes to yellow when hovered." />

Nếu bạn đang đọc trang cho bạn bè qua điện thoại, họ sẽ không quan tâm chấm màu đỏ trông như thế nào. Trong trường hợp này, lịch sử tham chiếu phim cũng rất quan trọng.

Khi viết văn bản mô tả, hãy cân nhắc xem hình ảnh truyền tải thông tin nào là quan trọng và phù hợp với người dùng và bao gồm yếu tố đó. Hãy nhớ rằng nội dung của thuộc tính alt cho một hình ảnh khác nhau tuỳ theo bối cảnh. Mọi thông tin được truyền tải trong một hình ảnh mà người dùng nhìn thấy có thể truy cập và phù hợp với bối cảnh là điều cần được truyền tải; không gì khác. Đảm bảo sự ngắn gọn, chính xác và hữu ích.

Thuộc tính srcalt là yêu cầu tối thiểu đối với hình ảnh được nhúng. Chúng ta cần thảo luận một số thuộc tính khác.

Hình ảnh thích ứng

Có vô số kích thước khung nhìn. Ngoài ra còn có nhiều độ phân giải màn hình. Bạn không muốn lãng phí thời gian bằng cách phân phối hình ảnh đủ rộng cho màn hình màn hình lớn, nhưng bạn có thể muốn phân phối độ phân giải cao hơn hình ảnh cho các thiết bị nhỏ có độ phân giải màn hình gấp bốn lần bình thường. Có một số cách để phân phát nhiều hình ảnh dựa trên kích thước khung nhìn và độ phân giải màn hình.

<img> srcset thuộc tính

Thuộc tính srcset cho phép đề xuất nhiều tệp hình ảnh, trong đó trình duyệt chọn hình ảnh cần yêu cầu dựa trên nhiều truy vấn phương tiện, bao gồm kích thước khung nhìn và độ phân giải màn hình.

Có thể có một thuộc tính srcset duy nhất cho mỗi phần tử <img>, nhưng srcset đó có thể liên kết đến nhiều hình ảnh. srcset chấp nhận danh sách các giá trị được phân tách bằng dấu phẩy, mỗi giá trị chứa URL của nội dung, theo sau là một dấu cách cho lựa chọn hình ảnh đó. Nếu sử dụng chỉ số mô tả chiều rộng, bạn cũng phải thêm thuộc tính sizes cùng với nội dung nghe nhìn truy vấn hoặc kích thước nguồn cho mỗi tuỳ chọn srcset khác với tuỳ chọn cuối cùng. Bạn nên đọc các phần Tìm hiểu về hình ảnh thích ứng có srcsetcú pháp mô tả.

Hình ảnh srcset sẽ được ưu tiên hơn hình ảnh src nếu có kết quả trùng khớp.

<picture><source>

Một phương pháp khác để cung cấp nhiều tài nguyên và cho phép trình duyệt hiển thị thành phần phù hợp nhất là sử dụng Phần tử <picture>. Phần tử <picture> là một vùng chứa phần tử cho nhiều tuỳ chọn hình ảnh được liệt kê với số lượng không giới hạn <source> và một phần tử <img> bắt buộc.

Các thuộc tính <source> bao gồm srcset, sizes, media, widthheight. Thuộc tính srcset chung cho img, sourcelink, nhưng thường được triển khai hơi khác trên nguồn vì truy vấn đa phương tiện có thể được liệt kê trong thuộc tính đa phương tiện của <srcset>. <source> cũng hỗ trợ các định dạng hình ảnh được xác định trong thuộc tính type.

Trình duyệt sẽ xem xét từng phần tử con <source> và chọn phần tử phù hợp nhất trong số đó. Nếu không tìm thấy kết quả trùng khớp, URL thuộc tính src của phần tử <img> được chọn. Tên thành phần hỗ trợ tiếp cận được lấy từ thuộc tính alt của <img> được lồng. Bạn cũng nên đọc những phần Tìm hiểu về phần tử <picture>cú pháp quy định.

Các tính năng nâng cao hiệu suất bổ sung

Tải từng phần

Thuộc tính loading cho trình duyệt đã bật JS biết cách tải hình ảnh. Giá trị eager mặc định có nghĩa là hình ảnh này được tải ngay khi HTML được phân tích cú pháp, ngay cả khi hình ảnh nằm ngoài khung nhìn hiển thị. Bằng cách đặt loading="lazy" thì việc tải hình ảnh sẽ bị trì hoãn cho đến khi hình ảnh có khả năng xuất hiện trong khung nhìn. "Có thể" được xác định bởi trình duyệt dựa trên khoảng cách hình ảnh được lấy từ khung nhìn. Nội dung này được cập nhật khi người dùng cuộn. Tính năng tải từng phần giúp tiết kiệm băng thông và CPU, từ đó cải thiện hiệu suất của hầu hết người dùng. Nếu JavaScript bị tắt, vì lý do bảo mật, tất cả hình ảnh sẽ được đặt mặc định thành eager.

<img src="switch.svg" alt="light switch" loading="lazy" />

Tỷ lệ khung hình

Trình duyệt bắt đầu hiển thị HTML khi nhận được và yêu cầu nội dung khi gặp HTML. Điều này có nghĩa là trình duyệt đã kết xuất HTML khi gặp thẻ <img> và đưa ra yêu cầu. Ngoài ra, việc tải hình ảnh có thể mất chút thời gian. Theo mặc định, các trình duyệt không dành riêng dung lượng cho hình ảnh ngoài kích thước cần thiết để hiển thị văn bản alt.

Phần tử <img> luôn hỗ trợ các thuộc tính heightwidth không đơn vị. Các tài sản này không được sử dụng nữa của CSS. CSS có thể xác định kích thước hình ảnh và thường đặt một kích thước duy nhất như max-width: 100%; để đảm bảo tỷ lệ khung hình được giữ nguyên. Vì CSS thường có trong <head>, nên CSS được phân tích cú pháp trước khi gặp bất kỳ <img> nào. Tuy nhiên, nếu không liệt kê rõ ràng height hoặc tỷ lệ khung hình, không gian dành riêng là chiều cao (hoặc chiều rộng) của văn bản alt. Hầu hết các nhà phát triển chỉ khai báo chiều rộng, việc nhận và hiển thị hình ảnh dẫn đến sự thay đổi bố cục tích lũy, gây hại cho các chỉ số quan trọng của trang web. Để giải quyết vấn đề này, các trình duyệt hỗ trợ tỷ lệ khung hình của hình ảnh. Việc đưa các thuộc tính heightwidth vào <img> đóng vai trò như gợi ý về kích thước, thông báo cho trình duyệt về tỷ lệ khung hình, cho phép lượng không gian được dành riêng để hiển thị hình ảnh sau cùng. Bằng cách bao gồm giá trị chiều cao và chiều rộng vào hình ảnh, trình duyệt biết tỷ lệ khung hình của hình ảnh đó. Khi trình duyệt gặp một kích thước duy nhất, chẳng hạn như ví dụ 50% của chúng tôi, trình duyệt sẽ tiết kiệm không gian cho hình ảnh tuân thủ kích thước CSS và với kích thước còn lại thì duy trì tỷ lệ khung hình giữa chiều rộng và chiều cao.

<img src="switch.svg" alt="light switch" role="img" width="70" height="112" />

Hình ảnh của bạn sẽ vẫn thích ứng nếu CSS được thiết lập đúng cách để chúng thích ứng. Có, tệp không có đơn vị đi kèm CSS sẽ ghi đè các giá trị heightwidth. Mục đích của việc thêm các thuộc tính này là để đặt chỗ tại tỷ lệ khung hình phù hợp, cải thiện hiệu suất bằng cách giảm sự thay đổi bố cục. Trang sẽ vẫn chiếm số tiền gần như tương tự nhưng giao diện người dùng sẽ không nhảy khi hình ảnh được vẽ lên màn hình.

Các tính năng khác của hình ảnh

Phần tử <img> cũng hỗ trợ crossorigin, decoding, referrerpolicy và trong các trình duyệt dựa trên Blink. fetchpriority. Hiếm khi được sử dụng, nếu hình ảnh là một phần của bản đồ phía máy chủ, hãy bao gồm thuộc tính boolean ismap và lồng <img> vào một liên kết cho người dùng mà không cần thiết bị trỏ.

Thuộc tính ismap là không cần thiết, thậm chí không được hỗ trợ, trên <input type="image" name="imageSubmitName"> dưới dạng xy toạ độ của vị trí nhấp được gửi trong quá trình gửi biểu mẫu, nối các giá trị vào tên mục nhập (nếu có). Ví dụ: nội dung nào đó như &imageSubmitName.x=169&imageSubmitName.y=66 sẽ được gửi cùng với biểu mẫu khi người dùng nhấp vào hình ảnh, gửi bản dịch đó. Nếu hình ảnh không có thuộc tính name, thì x và y sẽ được gửi: &x=169&y=66.

Kiểm tra kiến thức

Kiểm tra kiến thức của bạn về hình ảnh.

Hình ảnh nền trước phải luôn có 2 thuộc tính nào?

alt
size
src