Tải trước phông chữ web để cải thiện tốc độ tải

Garima Mimani
Garima Mimani

Lớp học lập trình này cho bạn biết cách tải trước phông chữ trên web bằng cách sử dụng rel="preload" để xoá mọi flash của văn bản chưa định kiểu (FOUT).

Đo

Trước tiên, hãy đo lường hiệu suất của trang web trước khi thêm bất kỳ tính năng tối ưu hoá nào.

  1. Để xem trước trang web, hãy nhấn vào Xem ứng dụng. Sau đó, nhấn vào biểu tượng Màn hình toàn cảnh toàn màn hình.
  2. Nhấn tổ hợp phím "Control + Shift + J" (hoặc "Command+Option+J" trên máy Mac) để mở Công cụ cho nhà phát triển.
  3. Nhấp vào thẻ Lighthouse (Tháp hải đăng).
  4. Đảm bảo bạn đã chọn hộp đánh dấu Hiệu suất trong danh sách Danh mục.
  5. Nhấp vào nút Tạo báo cáo.

Báo cáo Lighthouse được tạo sẽ cho bạn biết trình tự tìm nạp tài nguyên trong mục Độ trễ tối đa của đường dẫn quan trọng.

Phông chữ web có trong chuỗi yêu cầu quan trọng.

Trong quá trình kiểm tra ở trên, phông chữ trên web là một phần của chuỗi yêu cầu quan trọng và được tìm nạp sau cùng. Chuỗi yêu cầu quan trọng thể hiện thứ tự các tài nguyên được trình duyệt ưu tiên và tìm nạp. Trong ứng dụng này, phông chữ web (Pacfico và Pacifico-Bold) được xác định bằng quy tắc @font-face và là tài nguyên cuối cùng mà trình duyệt tìm nạp trong chuỗi yêu cầu quan trọng. Thông thường, phông chữ web được tải từng phần, tức là không tải cho đến khi tải xong các tài nguyên quan trọng (CSS, JS).

Dưới đây là trình tự của các tài nguyên được tìm nạp trong ứng dụng:

Phông chữ web được tải từng phần.

Tải trước phông chữ web

Để tránh FOUT, bạn có thể tải trước phông chữ web bắt buộc ngay lập tức. Thêm phần tử Link cho ứng dụng này ở đầu tài liệu:

<head>
 <!-- ... -->
 <link rel="preload" href="/assets/Pacifico-Bold.woff2" as="font" type="font/woff2" crossorigin>
</head>

Thuộc tính as="font" type="font/woff2" yêu cầu trình duyệt tải tài nguyên này xuống dưới dạng phông chữ và giúp ưu tiên hàng đợi tài nguyên.

Thuộc tính crossorigin cho biết liệu tài nguyên có được tìm nạp bằng yêu cầu CORS hay không vì phông chữ có thể đến từ một miền khác. Nếu không có thuộc tính này, trình duyệt sẽ bỏ qua phông chữ được tải trước.

Vì Pacifico-Bold được sử dụng trong tiêu đề trang, nên chúng ta đã thêm một thẻ tải trước để tìm nạp phông chữ này sớm hơn nữa. Việc tải trước phông chữ Pacifico.woff2 là không quan trọng vì phông chữ này tạo kiểu cho văn bản dưới màn hình đầu tiên.

Tải lại ứng dụng và chạy lại Lighthouse. Kiểm tra phần Độ trễ tối đa của đường dẫn quan trọng.

Phông web Pacifico-Bold được tải trước và bị xoá khỏi chuỗi yêu cầu quan trọng

Hãy lưu ý cách Pacifico-Bold.woff2 bị xoá khỏi chuỗi yêu cầu quan trọng. Tệp này được tìm nạp trước trong ứng dụng.

Phông chữ web Pacifico-Bold đã được tải trước

Với tính năng tải trước, trình duyệt sẽ biết rằng cần tải tệp này xuống sớm hơn. Xin lưu ý rằng nếu không được sử dụng đúng cách, tính năng tải trước có thể ảnh hưởng xấu đến hiệu suất do đưa ra các yêu cầu không cần thiết đối với những tài nguyên không được sử dụng.