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 membuat 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. Ia telah membangun situs agar penggemarnya dapat mempelajari konten favoritnya makanan tersebut. 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 tersebut berubah dari tony menjadi 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 data tentang 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:
- check_box Hapus Penyimpanan. Jika kotak centang ini diaktifkan, semua penyimpanan yang terkait dengan halaman tersebut akan dihapus sebelum setiap audit. Tetap aktifkan setelan ini jika Anda ingin mengaudit pengalaman pengunjung pertama kali di situs Anda. Nonaktifkan setelan ini saat Anda menginginkan pengalaman kunjungan berulang.
- check_box 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 more_vert 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. Alat ini disebut "simulasi" karena Lighthouse tidak benar-benar melakukan {i>throttle<i} 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 pemuatan halaman tunggal, dan itulah yang kita perlukan dalam tutorial ini. Untuk mengetahui informasi selengkapnya, lihat
- Perangkat > Seluler. Opsi seluler mengubah string agen pengguna dan menyimulasikan area pandang. Opsi {i>desktop<i} cukup menonaktifkan perubahan di perangkat seluler.
- Kategori > check_box Performa. Dengan satu kategori yang diaktifkan, Lighthouse membuat laporan hanya dengan serangkaian audit yang sesuai. Anda dapat membiarkan kategori lainnya tetap aktif, jika ingin melihat jenis rekomendasi yang diberikannya. Menonaktifkan kategori yang tidak relevan sedikit akan 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 mengalami error dalam laporan Lighthouse, coba jalankan tab demo dari jendela samaran tanpa tab lain yang terbuka. Hal ini memastikan bahwa Anda menjalankan Chrome dalam keadaan bersih. Ekstensi Chrome secara khusus dapat mengganggu proses audit.
Memahami laporan
Angka di bagian atas laporan Anda 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 berbagai aspek performa. 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
Berikutnya 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 memberikan tips tentang cara meningkatkan tingkat tinggi. 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 Header.
Telusuri bagian Respons Header untuk header
content-encoding
. Anda tidak akan melihatnya, yang berarti bahwabundle.js
tidak dikompresi. Saat resource dikompresi, header ini akan 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 Anda secara keseluruhan seharusnya 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 akan mengirim gambar dengan lebar maksimum 500 piksel.
Di laporan Anda, klik Sesuaikan gambar dengan ukuran yang tepat untuk melihat gambar yang perlu 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 tersebut hanya memiliki pengaruh kecil pada keseluruhan skor performa. Namun, satu hal bahwa skor tidak terlihat dengan jelas adalah berapa banyak data jaringan yang Anda simpan bagi 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 perubahan 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, Control+Shift+P
Mulai ketik
Coverage
, lalu pilih Tampilkan Cakupan.Tab Cakupan akan terbuka di Panel Samping.
Klik muat ulang Muat ulang. Tab Cakupan memberikan ringkasan tentang jumlah kode dalam
bundle.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 Sources. Sebuah baris kode dieksekusi jika terdapat bilah hijau di sebelahnya. Bilah merah di sebelah baris kode berarti kode tidak dieksekusi, dan benar-benar tidak diperlukan pada 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 menangani kode Anda sendiri, tab Cakupan dapat membantu 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 Show Request Blocking. Tab Minta Pemblokiran akan terbuka.Klik Tambahkan Pola, ketik
/libs/*
di kotak teks, lalu 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 Hapus semua 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 keseluruhan Anda seharusnya 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.
- Kecil kemungkinan Anda akan menemukan skrip yang dapat langsung dihapus, tetapi Anda akan sering menemukannya banyak skrip yang tidak perlu diminta selama pemuatan halaman, tetapi 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 Muat ulang. DevTools memuat ulang halaman, lalu menghasilkan visualisasi yang harus dilakukan untuk memuat halaman. Visualisasi ini akan disebut sebagai rekaman aktivitas.
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 bawah ke bagian 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 menggunakan perangkat para 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
.
Waktunya untuk 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 yang diperlukan.
Ringkasan
- Setiap kali Anda berupaya mengoptimalkan performa pemuatan situs, selalu mulai dengan audit. Audit menetapkan dasar, dan memberi Anda tips tentang cara menjadi lebih baik.
- Buat satu perubahan dalam satu waktu, dan audit laman setelah setiap perubahan untuk melihat bagaimana perubahan terisolasi itu memengaruhi kinerja.
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.
- Laporkan 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.