Ringkasan
Gunakan panel Lighthouse untuk menjalankan audit komprehensif terhadap situs Anda. Panel Lighthouse menghasilkan laporan yang memberikan insight tentang hal berikut tentang situs Anda:
- Performa
- Aksesibilitas
- Praktik Terbaik
- SEO
... dan banyak metrik lainnya.
Tutorial berikut membantu Anda memulai Lighthouse di Chrome DevTools.
Untuk mempelajari lebih lanjut cara lain yang dapat dilakukan Lighthouse untuk meningkatkan kualitas situs Anda, lihat dokumen Lighthouse kami.
Sasaran tutorial
Tutorial ini mengajarkan cara menggunakan Chrome DevTools untuk menemukan cara agar situs Anda dimuat lebih cepat.
Baca terus, atau tonton versi video dari tutorial ini:
Prasyarat
Anda harus memiliki pengalaman pengembangan web dasar, mirip dengan yang diajarkan di kelas Pengantar Pengembangan Web ini.
Anda tidak perlu mengetahui apa pun tentang performa pemuatan.
Pengantar
Ini Tony. Tony sangat terkenal di komunitas kucing. Dia telah membuat situs agar penggemarnya dapat mempelajari makanan favoritnya. Para penggemarnya menyukai situs tersebut, tetapi Tony terus mendengar keluhan bahwa situs dimuat dengan lambat. Tony telah meminta Anda untuk membantunya mempercepat situs itu.
Langkah 1: Mengaudit situs
Setiap kali Anda berupaya meningkatkan performa pemuatan situs, selalu mulai dengan audit. Audit memiliki dua fungsi penting:
- Alat ini membuat dasar bawaan untuk mengukur perubahan berikutnya.
- Halaman ini memberi Anda tips yang dapat ditindaklanjuti tentang perubahan apa yang akan memberikan dampak terbesar.
Siapkan
Pertama, Anda perlu menyiapkan lingkungan kerja baru untuk Situs Tony, agar Anda dapat membuat perubahan nanti:
Me-remix project situs di Glitch. Project baru Anda akan terbuka di tab. Tab ini akan disebut sebagai tab editor.
Nama project berubah dari tony menjadi beberapa nama yang dibuat secara acak. Anda kini memiliki salinan kode yang dapat diedit. Anda akan membuat perubahan pada kode ini nanti.
Di bagian bawah tab editor, klik Preview > Lihat pratinjau di jendela baru. Demo akan terbuka di tab baru. Tab ini akan disebut sebagai tab demo. Mungkin perlu waktu beberapa saat untuk memuat situs.
Buka DevTools bersamaan dengan demo.
Menetapkan dasar pengukuran
Dasar pengukuran adalah catatan performa situs sebelum Anda melakukan peningkatan performa.
Buka panel Lighthouse. Mungkin tersembunyi di balik
Panel lainnya.Cocokkan setelan konfigurasi laporan Lighthouse Anda dengan setelan yang ada di screenshot. Berikut adalah penjelasan mengenai opsi yang berbeda:
- Hapus Penyimpanan. Jika kotak centang ini diaktifkan, semua penyimpanan yang terkait dengan halaman akan dihapus sebelum setiap audit. Biarkan setelan ini aktif jika Anda ingin mengaudit pengalaman pengunjung pertama kali di situs Anda. Nonaktifkan setelan ini saat Anda menginginkan pengalaman kunjungan berulang.
- Aktifkan pengambilan sampel JS. Opsi ini dinonaktifkan secara default. Jika diaktifkan, stack panggilan JavaScript yang mendetail akan ditambahkan ke trace performa, tetapi dapat memperlambat pembuatan laporan. Rekaman aktivitas ini tersedia di bagian menu Alat > Lihat Rekaman Aktivitas yang Tidak Di-throttle setelah laporan Lighthouse dibuat.
- Simulasi throttling (default) . Opsi ini menyimulasikan kondisi umum penjelajahan di perangkat seluler. Ini disebut "simulasi" karena Lighthouse tidak benar-benar membatasi selama proses audit. Sebaliknya, hal ini hanya memperkirakan waktu yang diperlukan untuk memuat halaman dalam kondisi seluler. Di sisi lain, setelan DevTools throttling (lanjutan) sebenarnya men-throttle CPU dan jaringan Anda, tanpa kompromi dari proses pengauditan yang lebih lama.
- Mode > Tiga mode tersebut. Navigasi (Default). Mode ini menganalisis satu pemuatan halaman dan itulah yang kita perlukan dalam tutorial ini. Untuk mengetahui informasi selengkapnya, lihat
- Perangkat > Seluler. Opsi seluler mengubah string agen pengguna dan menyimulasikan viewport seluler. Opsi {i>desktop<i} cukup menonaktifkan perubahan di perangkat seluler.
- Kategori > Performa. Dengan satu kategori yang diaktifkan, Lighthouse membuat laporan hanya dengan serangkaian audit yang sesuai. Anda dapat membiarkan kategori lainnya tetap aktif, jika Anda ingin melihat jenis rekomendasi yang diberikannya. Menonaktifkan kategori yang tidak relevan akan sedikit mempercepat proses audit.
Klik Analisis pemuatan halaman. Setelah 10 hingga 30 detik, panel Lighthouse akan menampilkan laporan performa situs Anda.
Menangani error laporan
Jika Anda pernah mendapatkan error dalam laporan Lighthouse, coba jalankan tab demo dari jendela samaran tanpa membuka tab lain. Tindakan ini memastikan bahwa Anda menjalankan Chrome dari status bersih. Ekstensi Chrome secara khusus dapat mengganggu proses audit.
Memahami laporan
Angka di bagian atas laporan adalah skor performa keseluruhan untuk situs. Nanti, saat Anda membuat perubahan pada kode, Anda akan melihat kenaikan angka ini. Skor yang lebih tinggi berarti performa yang lebih baik.
Metrik
Scroll ke bawah ke bagian Metrik, lalu klik Luaskan tampilan. Untuk membaca dokumentasi tentang metrik, klik Pelajari lebih lanjut....
Bagian ini memberikan pengukuran kuantitatif performa situs. Setiap metrik memberikan insight tentang aspek performa yang berbeda. Misalnya, First Contentful Paint memberi tahu Anda saat konten pertama kali ditampilkan di layar, yang merupakan pencapaian penting dalam persepsi pemuatan halaman, sedangkan Waktu Untuk Interaktif menandai titik saat halaman tampak cukup siap untuk menangani interaksi pengguna.
Screenshot
Berikut adalah kumpulan screenshot yang menunjukkan tampilan halaman saat dimuat.
Peluang
Berikutnya adalah bagian Peluang yang memberikan tips spesifik tentang cara meningkatkan pemuatan halaman tertentu ini tingkat tinggi.
Klik peluang untuk mempelajarinya lebih lanjut.
Klik Pelajari lebih lanjut... untuk melihat dokumentasi tentang mengapa peluang itu penting dan spesifik rekomendasi tentang cara memperbaikinya.
Diagnostik
Bagian Diagnostik memberikan informasi lebih lanjut tentang faktor yang berkontribusi terhadap waktu pemuatan.
Lulus audit
Bagian Lulus audit menunjukkan tindakan yang dilakukan situs dengan benar. Klik untuk meluaskan bagian.
Langkah 2: Bereksperimen
Bagian Peluang di laporan Lighthouse memberi Anda tips tentang cara meningkatkan performa halaman. Di bagian ini, Anda akan menerapkan perubahan yang direkomendasikan pada codebase, dengan mengaudit situs setelah setiap perubahan untuk mengukur bagaimana pengaruhnya terhadap kecepatan situs.
Aktifkan kompresi teks
Laporan Anda menyatakan bahwa mengaktifkan kompresi teks adalah salah satu peluang utama untuk meningkatkan performa halaman.
Kompresi teks adalah ketika Anda mengurangi, atau mengompresi, ukuran file teks sebelum mengirimkannya melalui jaringan. Sama seperti bagaimana Anda dapat membuat zip folder sebelum mengirimkannya ke email untuk mengurangi ukurannya.
Sebelum mengaktifkan kompresi, berikut beberapa cara untuk memeriksa secara manual sumber daya akan dikompresi.
Buka panel Jaringan dan centang Gunakan baris permintaan besar.
Setelan >Setiap sel Size menunjukkan dua nilai. Nilai teratas adalah ukuran resource yang didownload. Tujuan
nilai terbawah adalah ukuran resource yang tidak dikompresi. Jika kedua nilai itu sama, maka
sumber daya tidak dikompresi saat
dikirim melalui jaringan. Dalam contoh ini,
nilai atas dan bawah untuk bundle.js
adalah 1.4 MB
.
Anda juga dapat memeriksa kompresi dengan memeriksa header HTTP resource:
Klik bundle.js dan buka tab Headers.
Telusuri bagian Respons Header untuk header
content-encoding
. Anda tidak akan melihatnya, yang berarti bahwabundle.js
tidak dikompresi. Saat resource dikompresi, header ini biasanya ditetapkan kegzip
,deflate
, ataubr
. Lihat Petunjuk untuk penjelasan mengenai hal ini masing-masing.
Cukup dengan penjelasannya. Saatnya membuat beberapa perubahan! Aktifkan kompresi teks dengan menambahkan beberapa baris kode:
Di tab editor, buka
server.js
dan tambahkan dua baris berikut (disorot):... const fs = require('fs'); const compression = require('compression'); app.use(compression()); app.use(express.static('build')); ...
Pastikan untuk menempatkan
app.use(compression())
sebelumapp.use(express.static('build'))
.Tunggu hingga Glitch men-deploy build baru situs tersebut. Emoji senang di sudut kiri bawah menunjukkan deployment yang berhasil.
Gunakan alur kerja yang Anda pelajari sebelumnya untuk memeriksa secara manual apakah kompresi berfungsi:
Kembali ke tab demo dan muat ulang halaman.
Kolom Ukuran kini menampilkan dua nilai yang berbeda untuk resource teks seperti
bundle.js
. Nilai teratas269 KB
untukbundle.js
adalah ukuran file yang dikirim melalui jaringan, dan nilai terbawah1.4 MB
adalah ukuran file yang tidak dikompresi.Bagian Header Respons untuk
bundle.js
kini harus menyertakan headercontent-encoding: gzip
.
Jalankan kembali laporan Lighthouse di halaman untuk mengukur dampak kompresi teks terhadap pemuatan halaman performa:
Buka panel Lighthouse dan klik Lakukan audit... pada panel tindakan di bagian atas.
Tetap gunakan setelan yang sama seperti sebelumnya, lalu klik Analisis pemuatan halaman.
Hore! Sepertinya ada kemajuan. Skor performa keseluruhan Anda seharusnya telah meningkat, yang berarti situs menjadi lebih cepat.
Kompresi teks di dunia nyata
Sebagian besar server benar-benar memiliki perbaikan sederhana seperti ini untuk mengaktifkan kompresi! Cukup lakukan penelusuran tentang untuk mengkonfigurasi server apa pun yang Anda gunakan untuk mengompresi teks.
Ubah ukuran gambar
Laporan baru Anda mengatakan bahwa mengubah ukuran gambar dengan benar adalah peluang besar lainnya.
Mengubah ukuran gambar akan membantu mempercepat waktu pemuatan dengan mengurangi ukuran file gambar. Jika pengguna Anda melihat gambar Anda pada layar perangkat seluler dengan lebar 500 piksel, benar-benar tidak ada gunanya mengirim gambar dengan lebar 1500 piksel. Idealnya, Anda mengirim gambar dengan lebar maksimal 500 piksel.
Dalam laporan, klik Ubah ukuran gambar dengan benar untuk melihat gambar yang harus diubah ukurannya. Sepertinya keempat gambar itu lebih besar dari yang diperlukan.
Kembali ke tab editor, buka
src/model.js
.Ganti
const dir = 'big'
denganconst dir = 'small'
. Direktori ini berisi salinan gambar yang sama yang telah diubah ukurannya.Audit halaman lagi untuk melihat bagaimana perubahan ini memengaruhi performa pemuatan.
Sepertinya perubahan ini hanya memiliki pengaruh kecil pada skor performa keseluruhan. Namun, satu hal yang tidak ditampilkan dengan jelas oleh skor ini adalah jumlah data jaringan yang Anda hemat untuk pengguna. Total ukuran foto lama sekitar 6,1 MB, padahal sekarang hanya sekitar 633 kB. Anda dapat memeriksanya di status bar di bagian bawah panel Network.
Mengubah ukuran gambar di dunia nyata
Untuk aplikasi kecil, melakukan pengubahan ukuran satu kali seperti ini mungkin sudah cukup. Tapi untuk aplikasi besar, jelas tidak skalabel. Berikut beberapa strategi untuk mengelola gambar di aplikasi besar:
- Ubah ukuran gambar selama proses build.
- Buat beberapa ukuran setiap gambar selama proses build, lalu gunakan
srcset
dalam kode Anda. Pada saat runtime, browser akan memilih ukuran yang terbaik untuk perangkat yang menjalankannya. Lihat Gambar berukuran relatif. - Gunakan CDN gambar yang memungkinkan Anda mengubah ukuran gambar secara dinamis saat Anda memintanya.
- Setidaknya, optimalkan setiap gambar. Hal ini sering kali dapat menghemat biaya yang sangat besar. Pengoptimalan adalah saat Anda menjalankan gambar melalui program khusus yang akan mengurangi ukuran file gambar. Lihat Penting Pengoptimalan Gambar untuk tips lainnya.
Menghilangkan resource yang memblokir render
Menurut laporan terbaru, menghilangkan resource yang memblokir rendering sekarang menjadi peluang terbesar.
Sumber daya pemblokir render adalah file JavaScript atau CSS eksternal yang harus diunduh browser, mengurai, dan mengeksekusi sebelum dapat menampilkan halaman. Tujuannya adalah untuk hanya menjalankan CSS dan JavaScript inti kode yang diperlukan untuk menampilkan halaman dengan benar.
Selanjutnya, tugas pertama adalah menemukan kode yang tidak perlu dieksekusi saat pemuatan halaman.
Klik Hilangkan aset yang memblokir render untuk melihat aset yang memblokir:
lodash.js
danjquery.js
.Bergantung pada sistem operasi Anda, tekan tombol berikut untuk membuka Menu Perintah:
- Di Mac, Command+Shift+P
- Di Windows, Linux, atau ChromeOS, Kontrol+Shift+P
Mulai ketik
Coverage
, lalu pilih Tampilkan Cakupan.Tab Cakupan akan terbuka di Panel samping.
Klik
Muat ulang. Tab Cakupan memberikan ringkasan tentang jumlah kode dalambundle.js
,jquery.js
, danlodash.js
yang dijalankan saat halaman dimuat.Tangkapan layar ini mengatakan bahwa masing-masing sekitar 74% dan 30% dari file jQuery dan Lodash tidak digunakan.
Klik baris jquery.js. DevTools akan membuka file di panel Sumber. Sebuah baris kode dieksekusi jika terdapat bilah hijau di sebelahnya. Batang merah di samping baris kode berarti kode tersebut tidak dieksekusi, dan tidak diperlukan saat pemuatan halaman.
Scroll kode jQuery sedikit. Beberapa baris yang "dijalankan" sebenarnya hanya komentar. Menjalankan kode ini melalui minifier yang menghapus komentar adalah cara lain untuk mengurangi ukuran file ini.
Singkatnya, saat Anda menggunakan kode sendiri, tab Cakupan dapat membantu Anda menganalisis kode, baris demi baris, dan hanya mengirimkan kode yang diperlukan untuk pemuatan halaman.
Apakah file jquery.js
dan lodash.js
memang diperlukan untuk memuat halaman? Tab Minta Pemblokiran dapat
menunjukkan apa yang terjadi
saat sumber daya tidak tersedia.
- Klik tab Jaringan dan buka Menu Perintah lagi.
Mulai ketik
blocking
, lalu pilih Tampilkan Pemblokiran Permintaan. Tab Minta Pemblokiran akan terbuka.Klik Tambahkan Pola, ketik
/libs/*
di kotak teks, dan tekan Enter untuk mengonfirmasi.Muat ulang halaman. Permintaan jQuery dan Lodash berwarna merah, artinya permintaan tersebut diblokir. Tujuan halaman masih dimuat dan bersifat interaktif, jadi sepertinya resource ini tidak diperlukan sama sekali.
Klik Remove all pola untuk menghapus pola pemblokiran
/libs/*
.
Secara umum, tab Pemblokiran Permintaan berguna untuk menyimulasikan perilaku halaman Anda saat resource tidak tersedia.
Sekarang, hapus referensi ke file ini dari kode dan audit halaman lagi:
- Kembali ke tab editor, buka
template.html
. Hapus tag
<script>
yang sesuai:<head> ... <meta name="viewport" content="width=device-width, initial-scale=1"> <script src="/libs/lodash.js"></script> <script src="/libs/jquery.js"></script> <title>Tony's Favorite Foods</title> </head>
Tunggu hingga situs dibangun ulang dan di-deploy ulang.
Audit kembali halaman dari panel Lighthouse. Skor Anda secara keseluruhan akan meningkat lagi.
Mengoptimalkan Jalur Rendering Penting di dunia nyata
Jalur Rendering Penting mengacu pada kode yang Anda perlukan untuk memuat halaman. Secara umum, Anda dapat dapat mempercepat pemuatan halaman dengan hanya mengirimkan kode penting selama pemuatan halaman, lalu pemuatan lambat segala hal lainnya.
- Anda mungkin tidak akan menemukan skrip yang dapat dihapus langsung, tetapi Anda akan sering menemukan bahwa banyak skrip tidak perlu diminta selama pemuatan halaman, dan dapat diminta secara asinkron. Lihat Menggunakan asinkron atau tunda.
- Jika Anda menggunakan framework, periksa apakah framework tersebut memiliki mode produksi. Mode ini dapat menggunakan fitur seperti sebagai tree shaking untuk menghilangkan kode tidak perlu yang memblokir render penting.
Melakukan lebih sedikit pekerjaan thread utama
Laporan terbaru Anda menunjukkan beberapa potensi penghematan kecil di bagian Peluang, tetapi jika Anda men-scroll ke bagian Diagnostik. Sepertinya bottleneck terbesar adalah terlalu banyak thread utama aktivitas Anda.
Thread utama adalah tempat browser melakukan sebagian besar pekerjaan yang diperlukan untuk menampilkan halaman, seperti mengurai dan mengeksekusi HTML, CSS, dan JavaScript.
Tujuannya adalah menggunakan panel Performance untuk menganalisis pekerjaan yang dilakukan thread utama saat pemuatan halaman, dan menemukan cara untuk menunda atau menghapus pekerjaan yang tidak perlu.
Buka Performa > Ambil Setelan dan tetapkan Jaringan ke 3G lambat dan CPU ke 6x lebih lambat.
Perangkat seluler biasanya memiliki lebih banyak batasan hardware dibandingkan laptop atau desktop, sehingga setelan ini memungkinkan Anda mengalami pemuatan halaman seolah-olah Anda menggunakan perangkat yang tidak terlalu canggih.
Klik
Muat ulang. DevTools memuat ulang halaman, lalu menghasilkan visualisasi yang harus dilakukan untuk memuat halaman. Visualisasi ini akan disebut sebagai trace.
Rekaman aktivitas menampilkan aktivitas secara kronologis, dari kiri ke kanan. Diagram FPS, CPU, dan NET di memberikan gambaran umum tentang {i>frame per detik<i}, aktivitas CPU, dan aktivitas jaringan.
Dinding berwarna kuning yang Anda lihat di bagian Overview berarti CPU benar-benar sibuk dengan aktivitas pembuatan skrip. Ini adalah petunjuk bahwa Anda mungkin dapat mempercepat pemuatan halaman dengan melakukan lebih sedikit pekerjaan JavaScript.
Selidiki rekaman aktivitas untuk menemukan cara melakukan lebih sedikit pekerjaan JavaScript:
Klik bagian Timings untuk meluaskannya.
Ada banyak pengukuran User Timing dari React, sepertinya aplikasi Tony menggunakan mode pengembangan React. Peralihan ke mode produksi React mungkin akan menghasilkan beberapa performa yang mudah.
Klik Timings lagi untuk menciutkan bagian tersebut.
Jelajahi bagian Utama. Bagian ini menunjukkan log kronologis dari aktivitas thread utama, dari kiri ke kanan. Sumbu y (atas ke bawah) menunjukkan alasan terjadinya peristiwa.
Dalam contoh ini, peristiwa
Evaluate Script
menyebabkan fungsi(anonymous)
dieksekusi, yang menyebabkan__webpack__require__
dieksekusi, yang menyebabkan./src/index.jsx
dieksekusi, dan seterusnya.Scroll ke bagian bawah Utama. Saat Anda menggunakan sebuah {i>framework<i}, sebagian besar aktivitas atas disebabkan oleh kerangka kerja, yang biasanya di luar kendali Anda. Aktivitas yang disebabkan oleh aplikasi Anda biasanya berada di bagian bawah.
Di aplikasi ini, sepertinya fungsi bernama
App
menyebabkan banyak panggilan ke fungsimineBitcoin
. Sepertinya Tony mungkin menggunakan perangkat penggemarnya untuk menambang mata uang kripto...Buka tab Bottom-Up di bagian bawah. Tab ini menguraikan aktivitas yang paling banyak menghabiskan waktu. Jika Anda tidak melihat apa pun di bagian Bottom-Up, klik label untuk bagian Utama.
Bagian Bottom-Up hanya menampilkan informasi untuk aktivitas atau grup aktivitas apa pun yang Anda miliki saat ini dipilih. Misalnya, jika Anda mengklik salah satu aktivitas
mineBitcoin
, Bagian Bottom-Up hanya akan menampilkan informasi untuk satu aktivitas tersebut.Kolom Waktu Mandiri menampilkan jumlah waktu yang dihabiskan langsung di setiap aktivitas. Dalam hal ini, sekitar 82% waktu thread utama dihabiskan untuk fungsi
mineBitcoin
.
Saatnya melihat apakah menggunakan mode produksi dan mengurangi aktivitas JavaScript mempercepat pemuatan halaman. Mulai dengan mode produksi:
- Di tab editor, buka
webpack.config.js
. - Ubah
"mode":"development"
menjadi"mode":"production"
. - Tunggu hingga build baru di-deploy.
Audit halaman lagi.
Kurangi aktivitas JavaScript dengan menghapus panggilan ke mineBitcoin
:
- Di tab editor, buka
src/App.jsx
. - Jadikan panggilan
this.mineBitcoin(1500)
diconstructor
sebagai komentar. - Tunggu hingga build baru di-deploy.
- Audit halaman lagi.
Seperti biasa, masih ada hal-hal yang perlu dilakukan, misalnya, kurangi metrik Largest Contentful Paint dan Pergeseran Tata Letak Kumulatif.
Melakukan lebih sedikit pekerjaan thread utama di dunia nyata
Secara umum, panel Performa adalah cara paling umum untuk memahami aktivitas yang dilakukan situs Anda saat dimuat, dan menemukan cara untuk menghapus aktivitas yang tidak perlu.
Jika Anda lebih memilih pendekatan yang terasa seperti console.log()
, User Timing API memungkinkan Anda
secara bebas menandai fase tertentu dari siklus hidup aplikasi Anda, untuk melacak berapa lama masing-masing fase
fase-fase itu.
Ringkasan
- Setiap kali Anda berupaya mengoptimalkan performa pemuatan situs, selalu mulai dengan audit. Audit ini menetapkan dasar pengukuran, dan memberi Anda tips tentang cara meningkatkannya.
- Lakukan satu perubahan pada satu waktu, dan audit halaman setelah setiap perubahan untuk melihat pengaruh perubahan terisolasi tersebut terhadap performa.
Langkah berikutnya
Jalankan audit di situs Anda sendiri. Jika Anda memerlukan bantuan dalam menafsirkan laporan atau menemukan cara untuk meningkatkan performa pemuatan, lihat semua cara untuk mendapatkan bantuan dari komunitas DevTools:
- Laporkan bug pada dokumen ini di repositori developer.chrome.com.
- Ajukan laporan bug di DevTools di Bug Chromium.
- Diskusikan fitur dan perubahan di Milis. Jangan gunakan milis untuk pertanyaan dukungan teknis IT. Sebagai gantinya, gunakan Stack Overflow.
- Dapatkan bantuan umum mengenai cara menggunakan DevTools di Stack Overflow. Untuk mengajukan permintaan bug, selalu gunakan Bug Chromium.
- Tweet kami di @ChromeDevTools.