


Saya mencuba perkara berikut untuk mengoptimumkan prestasi projek sampingan saya:
- mampatan teks
- pemisahan kod
- format imej moden.
Profiler
Aplikasi yang saya bina menggunakan Vite dengan pnpm. Alat binaan web moden secara automatik mengoptimumkan prestasi web secara lalai dalam proses binaan. Jadi kita boleh pnpm run build kemudian pnpm dlx serve dist. Kemudian gunakan Lighthouse of Chrome DevTools sebagai panduan untuk menangani setiap kesesakan yang disenaraikannya.
Dayakan pemampatan teks
Ia menjejaskan FCP dan LCP.
Perkara pertama yang dicadangkan Rumah Api ialah memampatkan teks menggunakan algoritma seperti br atau gzip.
Amalan biasa ialah menambah Accept-Encoding: gzip setiap kali membuat permintaan web. Memandangkan apl yang saya bina menyajikan sumber secara setempat, saya memasang vite-plugin-compress untuk memampatkan fail.
Langkah 1: pasang vite-plugin-compress
Langkah 2: konfigurasikan fail vite.config.js dan tambah pemalam serta beberapa parameter. Seperti yang dicadangkan oleh Pembangun Google, ia harus menggunakan br(brotliCompress) pada gzip sebanyak mungkin.
Contohnya
viteCompression({ verbose: true, disable: false, algorithm: 'brotliCompress', ext: '.br', }),
Langkah 3: jalankan pnpm run build untuk memampatkan
Ia berjaya memampatkan fail .js dan .css.
Log:
✨ [vite-plugin-compression]:algorithm=brotliCompress - berjaya dimampatkan fail.
Vite akan memampatkan fail secara lalai menggunakan .gzip, tetapi brotliCompress boleh melakukan lebih baik, pemampatan semasa proses binaan:
Vite dengan gzip
bangunan vite v5.4.10 untuk pengeluaran...
✓ 654 modul diubah.indeks-B9QUW17e.css 8.60 kB │ gzip: 2.33 kB
JedaMenu-DjZ95K-6.js 1.77 kB │ gzip: 0.62 kB
index-ohAKp9W9.js 1,688.05 kB │ gzip: 454.20 kBVite-plugin-compression dengan br
✨ [vite-plugin-compression]:algorithm=brotliCompress - fail dimampatkan berjaya:
JedaMenu-DjZ95K-6.js.br 1.73kb / brotliMampat: 0.51kb
index-B9QUW17e.css.br 8.40kb / brotliMampat: 1.97kb
index-ohAKp9W9.js.br 1648.49kb / brotliMampat: 345.30kb
Mengurangkan JavaScript yang tidak digunakan
Ia menjejaskan FCP dan LCP.
Gunakan Tab Liputan dalam Google DevTools untuk melihat skrip yang mempunyai bait yang tidak digunakan melebihi 20kbs.
Memandangkan saya menggunakan Vite dengan React, pemisahan kod ialah perkara pertama tentang mengurangkan JavaScript yang tidak digunakan.
Dalam React,
- Gunakan
untuk membalut keseluruhan Apl dan menyediakan UI sandaran, seperti Memuatkan, ini menyediakan UI sandaran apabila apl sedang dimuatkan. - Gunakan lazy() untuk membalut komponen yang tidak digunakan pada halaman awal. Contohnya, untuk permainan, apabila pengguna menekan kekunci Esc ke bawah, menu yang anda boleh bungkus akan muncul.
Layankan imej dengan format moden
Pembangun Chrome mencadangkan penyajian imej dalam format AVIF atau WebP. Saya memilih WebP kerana ia mempunyai lebih banyak sokongan merentas penyemak imbas.
Versi terkini Chrome, Firefox, Safari, Edge dan Opera menyokong WebP, manakala sokongan AVIF lebih terhad.
Anda boleh menyemak maklumat sokongan format imej WebP di Bolehkah saya menggunakan.
Anda boleh memasang pustaka cwebp di WebP dan gunakan arahan cwebp -q 50 images/flower1.jpg -o images/flower1.webp untuk menukar .png kepada .webp .
Arahan ini menukar, pada kualiti 50 (0 adalah yang paling teruk; 100 adalah yang terbaik), fail images/flower1.jpg dan menyimpannya sebagai images/flower1.webp.
Hasil pemampatan agak mengagumkan. Salah satu fail dikecilkan saiznya daripada 3.5 MB kepada 178kb. Malah keamatan maklumat yang rendah memberikan pemampatan 4x ganda.
Kami juga boleh menulis skrip .bat yang ringkas untuk menukar semua imej .png secara automatik di bawah folder sasaran kepada imej .webp.
viteCompression({ verbose: true, disable: false, algorithm: 'brotliCompress', ext: '.br', }),
Rujukan
- Alih keluar JavaScript yang tidak digunakan
- Lihat CSS yang digunakan dan tidak digunakan dengan tab Liputan.
- Layankan imej dalam format moden.
- Mencipta Imej WebP dengan Baris Perintah
- Utiliti Prapenyusun
- Format imej WebP - Bolehkah Saya Gunakan
- Cat Kandungan Terbesar (LCP)
- First Contentful Paint (FCP)
Atas ialah kandungan terperinci Pemampatan teks & Pemisahan kod & format imej moden - Pengoptimuman prestasi. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Penjelasan terperinci mengenai kaedah penggantian rentetan javascript dan Soalan Lazim Artikel ini akan meneroka dua cara untuk menggantikan watak rentetan dalam JavaScript: Kod JavaScript dalaman dan HTML dalaman untuk laman web. Ganti rentetan di dalam kod JavaScript Cara yang paling langsung ialah menggunakan kaedah pengganti (): str = str.replace ("cari", "ganti"); Kaedah ini hanya menggantikan perlawanan pertama. Untuk menggantikan semua perlawanan, gunakan ungkapan biasa dan tambahkan bendera global g: str = str.replace (/fi

Tutorial ini menunjukkan kepada anda bagaimana untuk mengintegrasikan API carian Google tersuai ke dalam blog atau laman web anda, menawarkan pengalaman carian yang lebih halus daripada fungsi carian tema WordPress standard. Ia menghairankan mudah! Anda akan dapat menyekat carian ke y

Jadi di sini anda, bersedia untuk mempelajari semua perkara ini yang dipanggil Ajax. Tetapi, apa sebenarnya? Istilah Ajax merujuk kepada kumpulan teknologi longgar yang digunakan untuk membuat kandungan web yang dinamik dan interaktif. Istilah Ajax, yang asalnya dicipta oleh Jesse J

Siri artikel ini ditulis semula pada pertengahan 2017 dengan maklumat terkini dan contoh segar. Dalam contoh JSON ini, kita akan melihat bagaimana kita dapat menyimpan nilai mudah dalam fail menggunakan format JSON. Menggunakan notasi pasangan nilai utama, kami boleh menyimpan apa-apa jenis

Leverage JQuery untuk Layouts Laman Web yang mudah: 8 Plugin Essential JQuery memudahkan susun atur laman web dengan ketara. Artikel ini menyoroti lapan plugin jQuery yang kuat yang menyelaraskan proses, terutamanya berguna untuk penciptaan laman web manual

Mata teras Ini dalam JavaScript biasanya merujuk kepada objek yang "memiliki" kaedah, tetapi ia bergantung kepada bagaimana fungsi dipanggil. Apabila tidak ada objek semasa, ini merujuk kepada objek global. Dalam penyemak imbas web, ia diwakili oleh tetingkap. Apabila memanggil fungsi, ini mengekalkan objek global; tetapi apabila memanggil pembina objek atau mana -mana kaedahnya, ini merujuk kepada contoh objek. Anda boleh mengubah konteks ini menggunakan kaedah seperti panggilan (), memohon (), dan mengikat (). Kaedah ini memanggil fungsi menggunakan nilai dan parameter yang diberikan. JavaScript adalah bahasa pengaturcaraan yang sangat baik. Beberapa tahun yang lalu, ayat ini

JQuery adalah rangka kerja JavaScript yang hebat. Walau bagaimanapun, seperti mana -mana perpustakaan, kadang -kadang perlu untuk mendapatkan di bawah tudung untuk mengetahui apa yang sedang berlaku. Mungkin kerana anda mengesan bug atau hanya ingin tahu tentang bagaimana jQuery mencapai UI tertentu

Siaran ini menyusun helaian cheat berguna, panduan rujukan, resipi cepat, dan coretan kod untuk perkembangan aplikasi Android, BlackBerry, dan iPhone. Tiada pemaju harus tanpa mereka! Panduan Rujukan Gesture Touch (PDF) Sumber yang berharga untuk desig


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

Dreamweaver Mac版
Alat pembangunan web visual

SublimeText3 versi Inggeris
Disyorkan: Versi Win, menyokong gesaan kod!

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma
