Cách đây vài hôm, mình nhận được một câu hỏi khá thú vị là: Trang Thế Giới Di Động (thegioididong.com) sử dụng công nghệ gì mà có thể tải nhanh chóng mặt như vậy?
Chỉ mất vài phút để mở web thế giới di động lên tìm hiểu, nhưng mình lại nhận được một câu trả lời vừa hay ho, vừa ngạc nhiên và vô cùng thú vị.
Nếu tò mò thì các bạn kéo xuống đọc tiếp nhé!
Full disclosure: Mình không được đồng quảng cáo nào khi khen team thegioididong đâu nhe 😉
Lưu ý: Vì không biết back-end của thế giới di động ra sao, mình chỉ có thể dự đoán được 2 điều sau về back-end:
- HTML được cache trong RAM của webserver hoặc web application nhằm giảm thiểu thời gian tải back-end (Nếu user chưa đăng nhập).
- Hệ thống CDN của thegioididong đặt tại nhiều nơi giúp tăng tốc độ tải resource (ảnh, css, js)
Do vậy, bài viết này chỉ nhằm phân tích về front-end của thế giới di động thôi nhé.
Công nghệ hiện đại … 12 năm tuổi?
Các bạn có thể xem ở giây thứ 5 trong hình dưới, thegioididong chỉ mất khoảng 1s để tải (Đã dùng Ctrl+F5 để xóa cache và load lại toàn bộ trang).

Bạn sẽ rất ngạc nhiên khi biết rằng, thegioididong không hề sử dụng bất kì framework hiện đại nổi tiếng nào (VueJS, ReactJS, AngularJS) và chỉ sử dụng những thứ cực kì căn bản:
- HTML được render hoàn toàn từ phía server (server side render)
- JS thuần + chút ít jQuery
Thế nhưng, chính những công nghệ “bình thường và cũ rích”, này (chứ không phải những thứ hay ho như React, Webpack) đã góp phần giúp thế giới di động đạt được tốc độ tải trang “thần thánh”.
Front-end được optimize cực tốt!
Lý do tgdd có tốc độ tải trang chóng mặt như vậy là vì phía front-end đã được optimize rất kĩ! Chúng ta hãy cùng thử phân tích xem:
1. Kích thước của trang vô cùng nhỏ
Khi mở Chrome Dev Tools của tgdd, ta sẽ thấy những request từ browser đến server
Với một trang web bán hàng, quá trời hình ảnh, tổng lưu lượng tải từ HTML, CSS, JS cho tới ảnh chỉ là 581KB, tức là chỉ bằng một tấm hình, kinh khủng chưa?

Quan sát kĩ một tí size ảnh, các bạn sẽ thấy ảnh của thegioididong rất nhỏ, chỉ tầm 20-40kb. Điều này cho thấy các ảnh đã được optimize rất kĩ. Họ cũng không dùng các thư viện như bootstrap để … giảm dung lượng trang.
Ngoài ra, trang còn áp dụng lazy load nên khi các bạn scroll xuống mới load các ảnh bên dưới. Do vậy, browser chỉ cần tải banner và 4, 5 tấm ảnh phía trên, giúp giảm được lưu lượng tải rất nhiều!
2. Xử lý CSS và JS đúng cách
Quan sát kĩ hơn, ta thấy thegioididong không hề tải file CSS nào, mà bỏ toàn bộ file CSS vào head. Làm như vậy, khi load xong HTML, browser không cần phải tải CSS mà có thể render ngay luôn.
Đây là một trick tăng tốc khá hay mà ít người biết. Bạn nào muốn tìm hiểu thêm có thể đọc bài này: Bỏ CSS vào head – Thời gian render giảm từ 378ms đến 225ms).
Do web chỉ có HTML tĩnh, không cần dùng JS để render nên file JavaScript được để phía dưới cùng, thêm tag defer. Tag này giúp browser thoải mái render HTML trước rồi mới chạy JavaScript.

3. Cache everything
Kiểm tra kĩ hơn, các bạn sẽ thấy những tài nguyên như ảnh, CSS, JS đều có head cache-control=31536000, tức browser sẽ cache các tài nguyên này trong 1 năm.
Do vậy, khi load lại trang, browser không cần phải tải lại ảnh, CSS, JS này nữa. Vừa đỡ nặng server, vừa tăng tốc độ tải. Đúng là một công đôi việc nhỉ?
Làm được như thegioididong có khó không?
Về backend thì mình không dám bàn về độ khó!
Để làm back-end 1 hệ thống có hàng triệu người dùng như thế giới di động, ta cần thiết kế architecture có tính scale cao, chưa kể từ webserver cho tới viết code và SQL query đều phải được optimize từng ly từng tí một.
Tuy nhiên, phần front-end thì lại khá dễ thực hiện, chỉ cần làm theo những guideline trong bài viết là xong:
- Optimize dung lượng tải trang (từ hình ảnh cho tới CSS, JS)
- Hạn chế dùng thư viện để giảm lưu lượng cần tải
- Thêm CSS vào head, JS không cần thiết thì để cuối trang.
- Cache tất tần tật đủ mọi thứ
Mấy cái này không phải mình tự nghiệm hay tự chém ra, mà do chính Google chia sẻ trong mục Web Performance nhé!
Ngoài ra các trang khác như Điện Máy Xanh, Bách Hóa Xanh va Trần Anh chắc cũng được sử dụng chung source code với Thế Giới Di Động nên cũng có load trang với tốc độ bàn thờ nốt!
Chốt
Hóa ra để làm một trang web với tốc độ “bàn thờ” cũng không khó lắm nhỉ!
Các bạn không tin thì cứ thử vào các trang web của mình làm xem! Chỉ là web tĩnh, không có back-end hầm hố nhưng front-end cũng load với tốc độ “bàn thờ”, không thua gì thegioididong đâu.
- Sách Code Dạo Kí Sự (nhiều hình)
- Sách Bảo Mật Nhập Môn
- Sách Nhập Môn Lập Trình Không Code
- CV Tôi Đi Code Dạo
Thế nhưng, đã bao giờ bạn tự hỏi: Tại sao các trang đối thủ như Tiki, Sendo,… không tải nhanh như thegioididong chưa? Bạn Code Dạo bảo là cải thiện tốc độ tải trang không khó mà?
Hãy đón xem phần sau, để cùng với mình … lật mặt tốc độ tải trang “rùa bò” của Sendo, Tiki,… nhé!
Bản thân mình thấy tiki tốc độ không thua gì thegioididong, với cả độ phức tạp trên homepage của tiki lại lớn hơn tgdd, còn sendo thì chậm thật
LikeLiked by 1 person
Hihi xem bài phân tích sau sẽ biết bạn nhé
LikeLike
bài viết rất hay 🙂 cám ơn anh nhiều =))
LikeLike
câu cuối là “Hãy đón xem phần sau” chứ anh :v lỗi nhỏ thôi nhưng e nghĩ là nên sửa vì đang đọc trôi chảy lại phải dừng lại ở đoạn này để ngẫm nghĩ
LikeLike
Ahihi già rồi nên hay nhầm á, tí a sửa nhé 😉
LikeLiked by 2 people
Anh ơi chỗ “artichecture” này sai chính tả nhé, phải là :architecture” nhé anh :D.
LikeLiked by 2 people
Sửa rồi e nhe, cảm ơn e hihi 😉
LikeLiked by 3 people
Em cũng có viết về TGDD, tiếc là xóa rồi và lười restore lại hehe. Website ở tên của em tối ưu theo bên đó, chắc thua mỗi phần tiền nhiều để sắm server mạnh thôi 😛
LikeLiked by 2 people
tốc độ load quá khủng, gần như chớp mắt @@ Sư phụ có nhận đệ tử không ạ
LikeLike
bạn có nhận thiết kế web ko bạn ơi. Mình cũng đang muốn tối ưu trang web của mình.
LikeLike
em mới học về web nên chỉ hiểu được đôi chút nhưng bài viết của anh rất hay ạ!! Cám ơn anh! Anh cố gắng ra nhiều bài hơn nữa nhé!!
LikeLiked by 3 people
like. giờ mới biết kỹ thuật đưa css vào head. thanks đại ca nhé
LikeLiked by 2 people
Hóa ra để làm một trang web với tốc độ “bàn thờ” cũng không khó lắm nhỉ! => Phản đối ku ơi!
Để làm được một trang đơn giản show hàng khoe tốc độ thì đơn giản. Tuy nhiên để có thể có được trang web như thế giới di động thì không hề đơn giản, cần một team đủ mạnh để có thể thực hiện được.
Đồng ý với một số luận điểm về mặt kĩ thuật để tăng tốc độ load có trong bài. Tuy nhiên, cái đáng nói ở đây là cái giá để đánh đổi lại.
Ví dụ không sử dụng bất cứ framework nào, bootstrap, angular, react… chỉ đơn thuần javascript, JQuery, css…không phải là điều đơn giản đối với trang web có tầm cỡ và có tính scale cao. Architecture phải tốt mới có thể thích ứng được trong điều kiện đòi hỏi liên tục thay đổi từ phía khách hàng. Công sức maintenance, phát triển thêm cũng không hề đơn giản.
LikeLiked by 4 people
Cảm ơn góp ý của anh nhé hihi
LikeLiked by 2 people
có gì không thể, cả đống web = c#, java có xài react, angular gì vẫn chạy ầm ầm, scale ào ào đấy thôi
LikeLike
Bài viết hay, cám ơn anh đã chia sẻ!!!
LikeLiked by 2 people
Làm sao follow các bài viết của bác đây :).
LikeLiked by 1 person
Bạn follow Fanpage trên Facebook nhé hihi https://www.facebook.com/toidicodedao
LikeLike
đưa css vào html thì được, e xem css của họ rất ít, khoảng 3 400 lines, có cách nào khắc phục nếu sử dụng thư viện ngoài như bootstrap, owl, nói chung các thư viện css ngoài ko ạ ?
LikeLike
Đó là về front. Còn back thì… nếu PHP thì cái đầu tiên hết là dẹp mấy cái php framework ra, bỏ ngay và luôn. Tự code cho 1 kiến trúc MCV đủ xài, uyển chuyển. Vd: PDO quá mạnh, có ngồi viết mấy câu lệnh $sql mà lười chảy thây ra học DB::select()…->get()… chả hiểu nổi… thì lấy đâu ra nhanh.
LikeLike
Cùng giao lưu nhé
LikeLike
thegioididong.com họ dùng ASP.NET MVC đấy bữa có hồi em tìm kiếm sản phẩm rồi nó hiện ra lỗi :))
LikeLike