Lớp học lập trình này hướng dẫn bạn cách tải trước phông chữ web bằng rel="preload"
để xoá mọi văn bản không theo 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.
- Để 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 .
- Nhấn tổ hợp phím `Ctrl+Shift+J` (hoặc `Command+Option+J` trên máy Mac) để mở DevTools.
- Nhấp vào thẻ Lighthouse (Tháp hải đăng).
- Đảm bảo bạn đã chọn hộp đánh dấu Hiệu suất trong danh sách Danh mục.
- 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.
Trong quy trình kiểm tra ở trên, phông chữ 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, nghĩa là chúng không được 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:
Tải trước phông chữ web
Để tránh lỗi FOUT, bạn có thể tải trước các phông chữ web cần thiết 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. Bạn không cần phải tải trước phông chữ Pacifico.woff2 vì phông chữ này tạo kiểu cho văn bản nằm 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.
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.
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. Điều quan trọng cần lưu ý là nếu không được sử dụng đúng cách, tính năng tải trước có thể gây hại cho hiệu suất bằng cách đưa ra các yêu cầu không cần thiết đối với các tài nguyên không được sử dụng.