Hướng dẫn lưu trữ Google Fonts ngay trên host để tăng tốc độ load website WordPress.
Trong bài viết lần trước, tôi đã hướng dẫn cách bạn cách để loại bỏ hoặc tải không đồng bộ Google Fonts nhằm tăng tốc độ load web rồi phải không nào? Mặc dù việc tải không đồng bộ (async) có thể giúp khắc phục lỗi chặn hiển thị trên Google PageSpeed Insights. Tuy nhiên, trên thực tế, nó vẫn được tải từ ngoài host và ảnh hưởng không nhỏ đến tốc độ load tổng thể của site do font không được cache và nén, đặc biệt là khi host của bạn đặt ở trong nước còn server Google đặt ở nước ngoài.
Tham khảo thêm:
- Khắc phục lỗi cache của Google Analytics một cách đơn giản
- Khắc phục lỗi Google Fonts trong Google PageSpeed Insights
Nếu bạn vẫn kiên quyết “không chịu từ bỏ” Google Fonts thì ngay sau đây là giải pháp tốt nhất giúp bạn thỏa mãn tâm nguyện. Chúng ta sẽ lưu trữ Google Fonts ngay trên host của bạn để tiện cho việc cache, nén cũng như tránh việc bị ảnh hưởng khi có sự cố… đứt cáp quang.
Lưu trữ Google Fonts ngay trên host của bạn
Xem mã nguồn blog/ website của bạn hoặc sử dụng các công cụ kiểm tra tốc độ load như Google PageSpeed Insights, bạn sẽ nhanh chóng tìm ra Google Fonts được dùng trên web.
<link rel='stylesheet' id='shopy-custom-fonts-css' href='//fonts.googleapis.com/css?family=Nunito%3Aregular%2C700%2C300%7CKameron%3Aregular%2C700%26subset%3Dlatin%2C' type='text/css' media='all' /> |
Trong ví dụ ở trên, web của tôi sử dụng font Nunito và font Kameron với các style regular, 300 và 700 với charset latin (nhìn vào cấu trúc link hoặc truy cập trực tiếp vào link font để xem thông tin). Ngay sau đây là hướng dẫn dể lưu trữ font Nunito trên host. Đối với các Google Fonts khác, các bạn cũng có thể làm theo cách hoàn toàn tương tự.
1. Đầu tiên, truy cập vào website Google Webfonts Helper. Nhập từ khóa tìm kiếm ở trên khung bên trái giao diện. Click vào kết quả tìm kiếm mà bạn mong muốn.
2. Trong mục Select charsets, hãy tick vào loại charset mà bạn muốn sử dụng:
3. Trong mục Select styles, hãy tick vào các style mà bạn muốn sử dụng. Ví dụ ở đây tôi chọn 300, 700 và regular.
4. Trong mục Copy CSS, hãy copy toàn bộ nội dung được cung cấp. Có 2 tùy chọn khác nhau:
- Best Support: là code hỗ trợ tất cả các trình duyệt, kể cả mới lẫn cũ. Các bạn nạn nên chọn loại code này.
- Modern Browsers: là code chỉ hỗ trợ các trình duyệt mới.
Các bạn cũng có thể tùy biến tên thư mục lưu trữ fonts bằng cách chỉnh sửa nội dung trong mục Customize folder prefix. Nếu không, hãy giữ nguyên như mặc định.
5. Download files chứa mã nguồn font về máy tính của bạn.
6. Sử dụng File Manager của cPanel/ DirectAdmin hoặc phần mềm FTP để truy cập vào thư mục cài đặt WordPress, tạo 1 thư mục có tên là fonts
, nằm ngang hàng với các thư mục như wp-content
, wp-admin
… Upload và giải nén file Google Fonts vừa download ở bước 5 vào trong đó.
7. Paste đoạn code CSS mà bạn đã copy ở bước 4 vào trong Appearance => Customize => Additional CSS hoặc sử dụng tính năng Custom CSS (nếu theme của bạn có hỗ trợ).
8. Sử dụng plugin Disable Google Fonts hoặc tính năng Remove Google Fonts (nằm trong tab Tuning) của plugin LiteSpeed Cache để loại bỏ code Google Fonts cũ.
Nếu bạn đang sử dụng plugin Autoptimize thì có một tính năng tương tự nằm trong Settings => Autoptimize => Extra => Google Fonts => Remove Google Fonts.
Xóa cache trình duyệt, cache web (nếu bạn có cài đặt plugin tạo cache) và kiểm tra thành quả. Thật đơn giản phải không nào? Chúc các bạn thành công!
Bạn có đang sử dụng Google Fonts trên blog/ website WordPress của mình không? Bạn đã làm cách nào để tối ưu chúng? Đừng quên chia sẻ với chúng tôi những kinh nghiệm và thủ thuật của bạn trong khung bình luận bên dưới.
Nếu bạn thích bài viết này, hãy subscribe blog của tôi để thường xuyên cập nhật những bài viết hay nhất, mới nhất qua email nhé. Cảm ơn rất nhiều. :)
Hay quá. Web bị điểm thấp toàn do mấy cái linh tinh từ bên thứ 3, trong đó có cả font google, có cách này ngon rồi.
Mình do bằng Gtmatrix mà thấy làm cách nè lại kém hơn về chỉ số Fully Loaded time, Total page size, thời gian load font cũng tăng từ 247ms lên 258ms
Điều đó chỉ chứng tỏ được một điều là tốc độ load file Google Fonts từ host của bạn đến server của GTmetrix chậm hơn load từ server của Google. Nó không đồng nghĩa với việc tốc độ load web trên trình duyệt của người dùng cũng chậm hơn. :P
cái plugin disable google font phải để đó luôn không đc xóa hả a
Đúng rồi bạn. Nó chỉ có tác dụng khi còn plugin thôi.
Dạ chào bác Hiếu, cho tên Tung cho em hỏi tí, Em có sài 2 font vậy cũng vẫn làm như cách Anh chia sẻ ở trên phải không ạ ?, nếu sài host ở Việt Nam thì dùng cách này se tăng tốc độ tải wed tốt hơn phải không ạ ? cám ơn bác nhiều, chúc bác và gia đình sức khỏe – an lành nhé
Đúng rồi bạn. :)
Chào bạn
CHo mình hỏi , mình đã làm như bạn và tốc độ tải trang tăng lên đáng kể . Tuy nhiên check thì thấy báo lỗi này :
Failed to load resource: the server responded with a status of 404 (Not Found) roboto-condensed-v17-latin-regular.woff2:1
Mình check trên host thì có file roboto-condensed-v17-latin-regular.woff2 ở trong thư mục fonts
Bạn check lại xem cái link kia là link internal hay external?
File đường dẫn trên host của em bác ah. https://abc.com/vi/wp-content/themes/fonts/roboto-condensed-v17-latin-regular.woff2
Em thấy trên host cũng có file này mà không hiểu sao nó vẫn báo lỗi.
Bạn tìm và sửa link kia thành link subdomain là được mà. Sửa thành https://sub.abc.com/themes/… là được.
Chào bác
Mình chưa hiểu ý bác lắm vì mình ko có dùng subdomain trên VPS ah
Bạn ơi cho mình hỏi. Sao khi mình làm cái này thì kiểm tra lại web thì nó không ra kết quả mà chỉ hiển thị dấu chấm hỏi (?). và bị lỗi 3 điểm: hình ảnh có ý nghĩa đầu tiền, thời điểm tương tác và CPU nhàn rỗi đầu tiền.
Thêm nữa là trong phần : Đảm bảo văn bản vẫn hiển thị trong khi tải phông chữ web. Sau khi cài fonts xong thì nó có thêm các đường link fonts từ host vừa cài với chỉ số là 2.540 ms . trong khi trước đó mình dùng fonts google thì chỉ số chỉ có 30 20 hoặc 10 thôi. Mà bây giờ nó tồn tại luôn cả 2 thứ đó luôn. Cảm ơn!!
Bài viết khá bổ ích
Mình thấy giờ cũng có 1 số themes có sẵn tính năng này trong themes option luôn đó AD