- Tổng đài 24/7: 1800 646 881
- Đăng nhập
- 3
Hình ảnh là phần quan trọng đối với trang web và ứng dụng có nhiều khả năng như biểu ngữ tiếp thị, quảng cáo sản phẩm hay minh hoạ logo… Tuy nhiên, với các kích thước quá lớn sẽ làm ảnh hưởng đến chất lượng hình ảnh và khả năng hiển thị trên trang web. Đừng quá lo lắng bởi Lazy Loading Image ra đời là giải pháp khắc phục các vấn đề này. Đồng thời kỹ thuật này còn giúp cải thiện hiệu suất và tăng trải nghiệm của người dùng. Hãy cùng BKHOST tìm hiểu chi tiết trong bài viết dưới đây.
Lazy Loading Image là một kỹ thuật giúp cải thiện hiệu suất hoạt động của các trang web bằng cách tải lên các hình ảnh hiển thị cần thiết thay vì tải lên trước. Đồng thời còn giúp tối ưu hoá mức sử dụng tài nguyên hệ thống và giảm các chi phí liên quan khác.
Lazy Loading Image có các ưu điểm chính như:
Sử dụng công cụ kiểm tra Google Lighthouse giúp xác định những hình ảnh phù hợp với Lazy Loading để có thể tối ưu số lượng bit tải trang. Hoặc trình phân tích trang web của ImageKit cũng có khả năng xác định tính năng hỗ trợ Lazy Loading của trang web và các tối ưu hoá khác liên quan đến hình ảnh. Vì vậy mà Lazy Loading mang đến cho người dùng những trải nghiệm tuyệt vời khi truy cập vào các trang web yêu thích.
Lazy Loading Image sử dụng thẻ <img>
hoặc thuộc tính CSS để tải các hình ảnh trên trang web.
Quá trình thực hiện Lazy Loading Image trong thẻ <img>
gồm hai bước:
Bước 1: Sử dụng thuộc tính src
của thẻ <img>
để kích hoạt tải hình ảnh lên trình duyệt.
Bước 2: Gắn URL hình ảnh vào thuộc tính khác src như data-src
của thẻ <img>
.
Đây là một src trống và trình duyệt sẽ không kích hoạt tải hình ảnh cho đến khi được yêu cầu.
{{EJS0}}
Các sự kiện như scroll
, resize
, và orientationChange
có thể thay đổi kích thước theo cửa sổ trình duyệt. Trong đó sự kiện OrientationChange được kích hoạt theo chế độ xoay màn hình của thiết bị. Đồng thời số lượng hình ảnh hiển thị cần kích hoạt tải cũng sẽ thay đổi.
Khi một sự kiện bất kỳ được kích hoạt cho phép tìm kiếm các hình ảnh ở mọi trạng thái khác nhau. Các hình ảnh đang hiển thị ở chế độ xem được gắn vào thuộc tính src có URL từ thuộc tính data-src
.
Các sự kiện khi cuộn sẽ được kích hoạt liên tục để tăng thời gian chờ cho Lazy Loading.
Ví dụ:
Trong ví dụ trên, 3 hình ảnh đầu tiên được gắn với thuộc tính src
của URL giúp chúng có thể hiển thị trực tiếp. Các hình ảnh này sẽ hiển thị sớm hơn mà không cần hỗ trợ của sự kiện hay thư viện JS.
Intersection Observer API là một kỹ thuật có khả năng nhận biết một phần tử bất kỳ đi đến chế độ xem và thực hiện tải ảnh ngay lập tức. Thay vì liên kết các sự kiện, công cụ API này sẽ làm đơn giản hóa quá trình tải và mang lại hiệu suất hoạt động mạnh mẽ hơn.
Ví dụ: Lazy Loading Image sử dụng API Intersection Observer:
Các hình ảnh được sử dụng cho Lazy Loading đều được đính kèm Intersection Observer. Khi API phát hiện phần tử vào chế độ xem lập tức di chuyển từ thuộc tính data-src
tới thuộc tính src của URL để trình duyệt kích hoạt tải hình ảnh. Hoàn tất quá trình thì lớp Lazy và Intersection Observer cũng sẽ bị xoá bỏ.
So sánh giữa hai phương pháp kích hoạt:
Native lazy loading có khả năng hỗ trợ cho Lazy Loading Image và iframes hoạt động bình thường ngay cả khi JavaScript bị vô hiệu hóa trên trình duyệt của người dùng.
Tính năng Lazy Loading đã được bổ sung vào phiên bản Chrome 76 và các trình duyệt dựa trên Chromium như Chrome, Edge, Safari và Firefox với mục đích chỉ tải hình ảnh thực sự cần thiết trên trang web.
HTML dành cho quản trị viên trang web hỗ trợ triển khai thuộc tính Loading với dòng code:
{{EJS1}}
Một số thuộc tính của Loading dành cho các trình duyệt không hỗ trợ tính năng Native Lazy Loading:
Để tránh trường hợp trùng lặp tải hình ảnh, các thuộc tính kích thước cần được bổ sung vào thẻ <img>
hoặc thông qua các giá trị nội tuyến như:
{{EJS2}}
Background cũng là một kỹ thuật tải hình ảnh cần thiết khi được yêu cầu. Các trình duyệt dựa trên DOM/CSSOM để tải các CSS Background phù hợp với trang web. Đây là một mẹo nhỏ khá hiệu quả dành cho trình duyệt hỗ trợ tải CSS Background vào chế độ xem.
Ví dụ: Nếu CSS Background phù hợp với một phần tử trong tài liệu thì trình duyệt sẽ tiến hành tải hình ảnh lên và ngược lại.
Điểm chung đầu tiên đó là các kỹ thuật đều có cùng mã JavaScript. Còn Intersection Observer API được sử dụng cho trình nghe sự kiện dự phòng dựa trên CSS.
Phần tử gồm ID bg-image
có Background được chỉ định trong CSS sau khi được thêm một lớp Lazy thì các giá trị sẽ được đặt thành không. Việc kết hợp này đem lại hiệu quả cao hơn so với #bg-image
độc lập.
Một số công ty thương mại điện tử cho rằng Lazy Loading Image giúp cải thiện thời gian tải ban đầu tốt hơn và giảm tiêu thụ băng thông đáng kể. Còn một số lại cho rằng Lazy Loading Image có thời gian tải chậm và ảnh hưởng đến chế độ xem của người dùng.
Các giải pháp khắc phục thời gian tải chậm hình ảnh của trang web:
Placeholders nằm trong container và các hình ảnh chỉ được tải lên khi có yêu cầu. Placeholder thường được thiết kế các màu giống nhau cho hình ảnh hoặc một tập hình ảnh.
Ví dụ: Màu xám đồng nhất được sử dụng cho Background của tất cả hình ảnh có trên trang web.
Kỹ thuật sử dụng dominant color placeholder được ứng dụng phổ biến như Google hoặc Pinterest. Hay với công cụ ImageKit có khả năng thiết lập màu chủ đạo cho placeholder bằng cách biến đổi một chuỗi.
Ví dụ:
URL hình ảnh giữ chỗ màu chủ đạo bằng ImageKit:
{{EJS3}}
Trong đó, các placeholder image của trình duyệt chỉ có kích thước 661 bit và nhẹ hơn tới 19 lần so với kích thước thực là 12.700 bit.
Video minh họa hoạt động của hiệu ứng này đối với người dùng:
Low quality image placeholder – LQIP là placeholder image chất lượng thấp hỗ trợ mở rộng các ý tưởng và cải thiện trải nghiệm tải hiển thị hình ảnh nhanh chóng hơn. Kỹ thuật này được Facebook và Medium.com lựa chọn sử dụng để nâng cao chất lượng hình ảnh trên trang web và ứng dụng.
Ví dụ:
URL hình ảnh LQIP sử dụng ImageKit:
{{EJS4}}
LQIP hỗ trợ các hình ảnh có kích thước 1300 bit và nhỏ hơn tới 10 lần so với kích thước thực.
Thời gian tải hình ảnh vào chế độ xem của trình duyệt cũng ảnh hưởng đến trải nghiệm của người dùng.
Vấn đề:
Giải pháp:
Vấn đề:
Hình ảnh quyết định kích thước nội dung hiển thị xung quanh container của trình duyệt. Nếu hình ảnh không được chỉ định kích thước thì trình duyệt sẽ xử lý chúng phù hợp với kích thước xung quanh container. Điều này sẽ khiến cho các yếu tố khác cũng bị di chuyển bất ngờ và làm ảnh hưởng đến trải nghiệm của người dùng.
Giải pháp:
Hãy thiết lập kích thước xung quanh container trên trình duyệt phù hợp với các hình ảnh.
Việc tải tất cả hình ảnh lên trang web sẽ làm ảnh hưởng đến thời gian tải trang ban đầu khiến người dùng cảm thấy khó chịu. Sau đây là một số nguyên tắc tải hình ảnh dành cho bạn:
Các tính năng của Lazy Loading phụ thuộc vào tính khả dụng của JavaScript trong trình duyệt. Kỹ thuật Native Lazy Loading không hoàn toàn hỗ trợ trình duyệt và thư viện JS là lựa chọn thích hợp hơn dành cho trải nghiệm của bạn. Hoặc thẻ <noscript>
cũng có khả năng cải thiện mức độ trải nghiệm của người dùng.
Hầu hết khả năng thực thi JavaScript đều được bật sẵn trong trình duyệt của người dùng. Tuy nhiên, với một số người dùng sẽ không muốn sử dụng hỗ trợ JavaScript cho trình duyệt của mình. Người dùng có thể nhận được các thông báo giải thích một số lỗi xảy ra như hình ảnh không được tải, mong muốn chuyển đổi trình duyệt hoặc yêu cầu bật thực thi JavaScript.
Các trình duyệt và thiết bị khác nhau sẽ cung cấp các môi trường truy cập và triển khai khác nhau. Vì vậy các thư viện và nền tảng plugin được thử nghiệm sẽ là lựa chọn thích hợp dành cho Lazy Loading trên trang web.
Một thư viện Lazy dựa trên jquery đơn giản.
Tiện ích mở rộng Magento 2 dành cho lazy loading images.
Tiện ích mở rộng Magento 1.x dành cho Lazy Loading Image.
Plugin hỗ trợ Lazy Loading Image dành cho WordPress.
Để kiểm tra trạng thái hoạt động của Lazy Loading sau khi hoàn tất triển khai trên trang web bằng cách:
Như vậy trên đây là tất cả các thông tin liên quan đến Lazy Loading Image mà chúng tôi muốn gửi đến bạn. Kỹ thuật này gồm có nhiều tính năng được triển khai nhằm cải thiện hiệu suất trang web, giảm kích thước trang và chi phí sử dụng tài nguyên.
Nếu bạn có thắc mắc về Lazy Loading Image hoặc những giải pháp giúp cải thiện hiệu suất trang web, hãy để lại ở bên bình luận bên dưới, BKHOST sẽ trả lời bạn trong thời gian sớm nhất.
P/s: Bạn cũng có thể truy cập vào Blog của BKHOST để đọc thêm các bài viết chia sẻ kiến thức về lập trình, quản trị mạng, website, domain, hosting, vps, server, email,… Chúc bạn thành công.
Mua Cloud Server tại BKHOST
Giảm giá cực sâu, chất lượng hàng đầu. Đăng ký ngay hôm nay: