


js untuk menghalang susun atur DIV daripada berkelip apabila kemahiran menatal_javascript
Contoh dalam artikel ini menerangkan kaedah js untuk menghalang reka letak DIV daripada berkelip apabila menatal, dan saya ingin berkongsi dengan anda untuk rujukan anda. Kaedah khusus adalah seperti berikut:
Perkara yang saya telah didedahkan baru-baru ini tentang prestasi halaman termasuk banyak kandungan halus dan asli, seperti pemaparan penyemak imbas. Terdapat banyak maklumat, jadi saya memilih beberapa untuk petikan dan memo.
Apabila JavaScript menulis dan membaca DOM beberapa kali, "layout thrashing" akan berlaku, menyebabkan pengaliran semula dokumen (reflow – proses membina pepohon render
// Baca
var h1 = element1.clientHeight;
// Tulis (reka letak tidak sah)
element1.style.height = (h1 * 2) 'px';
// Baca (letak letak pencetus)
var h2 = element2.clientHeight;
// Tulis (reka letak tidak sah)
element2.style.height = (h2 * 2) 'px';
// Baca (letak letak pencetus)
var h3 = element3.clientHeight;
// Tulis (reka letak tidak sah)
element3.style.height = (h3 * 2) 'px';
Apabila DOM ditulis, reka letak tidak sah dan perlu disusun semula pada masa tertentu. Tetapi pelayar sangat malas, ia mahu menunggu sehingga penghujung operasi semasa (atau bingkai) sebelum mengalir semula.
Walau bagaimanapun, jika kita membaca nilai geometri dari DOM sebelum penghujung operasi semasa (atau bingkai), maka kita akan memaksa pelayar untuk menyusun semula susun atur terlebih dahulu Ini adalah apa yang dipanggil "susun atur segerak paksa", yang akan Ia membunuh prestasi.
Pada penyemak imbas desktop moden, kesan sampingan meronta-ronta reka letak mungkin tidak jelas, tetapi pada peranti mudah alih rendah, masalahnya adalah serius.
Penyelesaian pantas
Dalam dunia yang ideal, kita boleh membaca DOM dan menulis DOM dalam kelompok dengan hanya menyusun semula susunan pelaksanaan kod. Ini bermakna dokumen itu hanya perlu dialirkan semula sekali.
var h1 = element1.clientHeight;
var h2 = element2.clientHeight;
var h3 = element3.clientHeight;
// Tulis (reka letak tidak sah)
element1.style.height = (h1 * 2) 'px';
element2.style.height = (h2 * 2) 'px';
element3.style.height = (h3 * 2) 'px';
// Pengaliran semula dokumen pada hujung bingkai
Bagaimana dengan dunia sebenar?
Sebenarnya ia tidak semudah itu. Dalam program besar, kod tersebar di mana-mana, dan DOM berbahaya ini wujud di mana-mana. Kami tidak boleh dengan mudah (dan jelas sekali tidak) menguli kod kami yang cantik dan dipisahkan bersama hanya untuk mengawal susunan pelaksanaan. Jadi untuk mengoptimumkan prestasi, bagaimana kita membatch membaca dan menulis?
Memenuhi permintaanAnimationFrame
window.requestAnimationFrame menjadualkan fungsi untuk dilaksanakan dalam bingkai seterusnya, serupa dengan setTimout(fn, 0). Ini sangat berguna kerana kita boleh menggunakannya untuk menjadualkan semua operasi tulis DOM untuk dilaksanakan bersama dalam bingkai seterusnya dan operasi baca DOM untuk dilaksanakan serentak dalam susunan semasa.
var h1 = element1.clientHeight;
// tulis
requestAnimationFrame(function() {
element1.style.height = (h1 * 2) 'px';
});
// Baca
var h2 = element2.clientHeight;
// tulis
requestAnimationFrame(function() {
element2.style.height = (h2 * 2) 'px';
});
……
Saya harap artikel ini akan membantu pengaturcaraan web semua orang berdasarkan JavaScript.

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

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Sambungan MySQL mungkin disebabkan oleh sebab -sebab berikut: Perkhidmatan MySQL tidak dimulakan, firewall memintas sambungan, nombor port tidak betul, nama pengguna atau kata laluan tidak betul, alamat pendengaran di my.cnf dikonfigurasi dengan tidak wajar, dan lain -lain. Langkah -langkah penyelesaian masalah termasuk: 1. 2. Laraskan tetapan firewall untuk membolehkan MySQL mendengar port 3306; 3. Sahkan bahawa nombor port adalah konsisten dengan nombor port sebenar; 4. Periksa sama ada nama pengguna dan kata laluan betul; 5. Pastikan tetapan alamat mengikat di my.cnf betul.

Penyelesaian kepada ralat pemasangan MySQL adalah: 1. Berhati -hati memeriksa persekitaran sistem untuk memastikan keperluan perpustakaan ketergantungan MySQL dipenuhi. Sistem operasi dan keperluan versi yang berbeza adalah berbeza; 2. Berhati -hati membaca mesej ralat dan mengambil langkah -langkah yang sepadan mengikut arahan (seperti fail perpustakaan yang hilang atau kebenaran yang tidak mencukupi), seperti memasang kebergantungan atau menggunakan arahan sudo; 3 Jika perlu, cuba pasang kod sumber dan periksa dengan teliti log kompilasi, tetapi ini memerlukan pengetahuan dan pengalaman Linux tertentu. Kunci untuk menyelesaikan masalah akhirnya adalah dengan teliti memeriksa persekitaran sistem dan maklumat ralat, dan merujuk kepada dokumen rasmi.

Sebab utama mengapa anda tidak boleh log masuk ke MySQL sebagai akar adalah masalah kebenaran, ralat fail konfigurasi, kata laluan tidak konsisten, masalah fail soket, atau pemintasan firewall. Penyelesaiannya termasuk: periksa sama ada parameter pengikat di dalam fail konfigurasi dikonfigurasi dengan betul. Semak sama ada kebenaran pengguna root telah diubahsuai atau dipadam dan ditetapkan semula. Sahkan bahawa kata laluan adalah tepat, termasuk kes dan aksara khas. Semak tetapan dan laluan kebenaran fail soket. Semak bahawa firewall menyekat sambungan ke pelayan MySQL.

Terdapat banyak sebab mengapa permulaan MySQL gagal, dan ia boleh didiagnosis dengan memeriksa log ralat. Penyebab umum termasuk konflik pelabuhan (periksa penghunian pelabuhan dan ubah suai konfigurasi), isu kebenaran (periksa keizinan pengguna yang menjalankan perkhidmatan), ralat fail konfigurasi (periksa tetapan parameter), rasuah direktori data (memulihkan data atau membina semula ruang meja), isu ruang jadual InnoDB (semak fail ibdata1) Apabila menyelesaikan masalah, anda harus menganalisisnya berdasarkan log ralat, cari punca utama masalah, dan mengembangkan tabiat sandaran data secara teratur untuk mencegah dan menyelesaikan masalah.

Langkah -langkah berikut boleh digunakan untuk menyelesaikan masalah yang tidak dapat disambungkan oleh Navicat ke pangkalan data: periksa sambungan pelayan, pastikan pelayan berjalan, alamat dan port dengan betul, dan firewall membolehkan sambungan. Sahkan maklumat log masuk dan sahkan bahawa nama pengguna, kata laluan dan kebenaran adalah betul. Semak sambungan rangkaian dan menyelesaikan masalah rangkaian seperti kegagalan penghala atau firewall. Lumpuhkan sambungan SSL, yang mungkin tidak disokong oleh beberapa pelayan. Semak versi pangkalan data untuk memastikan versi Navicat serasi dengan pangkalan data sasaran. Laraskan tamat masa sambungan, dan untuk sambungan jauh atau lebih perlahan, tingkatkan waktu tamat masa sambungan. Penyelesaian lain, jika langkah -langkah di atas tidak berfungsi, anda boleh cuba memulakan semula perisian, menggunakan pemacu sambungan yang berbeza, atau merujuk kepada pentadbir pangkalan data atau sokongan navicat rasmi.

Sebab utama kegagalan pemasangan MySQL adalah: 1. Isu kebenaran, anda perlu menjalankan sebagai pentadbir atau menggunakan perintah sudo; 2. Ketergantungan hilang, dan anda perlu memasang pakej pembangunan yang relevan; 3. Konflik pelabuhan, anda perlu menutup program yang menduduki port 3306 atau mengubah suai fail konfigurasi; 4. Pakej pemasangan adalah korup, anda perlu memuat turun dan mengesahkan integriti; 5. Pembolehubah persekitaran dikonfigurasikan dengan salah, dan pembolehubah persekitaran mesti dikonfigurasi dengan betul mengikut sistem operasi. Selesaikan masalah ini dan periksa dengan teliti setiap langkah untuk berjaya memasang MySQL.

MySQL tidak menyokong jenis array pada dasarnya, tetapi dapat menyelamatkan negara melalui kaedah berikut: JSON Array (kecekapan prestasi yang dikekang); pelbagai bidang (skalabilitas yang lemah); Jadual bersekutu (yang paling fleksibel dan sesuai dengan idea reka bentuk pangkalan data relasi).

Rasuah fail konfigurasi MySQL boleh dibaiki melalui penyelesaian berikut: 1. 2. Rekonstruksi Lengkap: Jika rasuah serius atau fail konfigurasi tidak dapat dijumpai, rujuk dokumen rasmi atau salin fail konfigurasi lalai versi yang sama, dan kemudian ubah suai mengikut keperluan; 3. Gunakan program pemasangan untuk menyediakan fungsi pembaikan: Cuba untuk membaiki fail konfigurasi secara automatik menggunakan fungsi pembaikan yang disediakan oleh pemasang. Selepas memilih penyelesaian yang sesuai untuk membaikinya, anda perlu memulakan semula perkhidmatan MySQL dan mengesahkan sama ada ia berjaya dan membangunkan tabiat sandaran yang baik untuk mengelakkan masalah tersebut.
