


Dua cara untuk memuatkan fail JavaScript_petua javascript secara dinamik
Artikel ini terutamanya memperkenalkan dua kaedah memuatkan fail JavaScript secara dinamik Rakan-rakan yang berminat boleh merujuknya
Yang pertama ialah menggunakan ajax untuk memuatkan kod fail skrip dari latar belakang ke latar depan, dan kemudian laksanakan kod melalui eval() pada kandungan yang dimuatkan. Yang kedua ialah membuat teg skrip secara dinamik, mengkonfigurasi atribut srcnya dan memuatkan js dengan memasukkan teg skrip ke dalam kepala halaman, yang bersamaan dengan menulis
Contohnya, jika kami ingin memuatkan callbakc.js secara dinamik, kami memerlukan teg skrip sedemikian:
Kodnya adalah seperti berikut:
Kod berikut ialah cara membuat teg ini melalui js (dan tambahkannya pada kepala):
Kodnya adalah seperti berikut:
var head= document.getElementsByTagName('head')[0]; var script= document.createElement('script'); script.type= 'text/javascript'; script.src= 'call.js'; head.appendChild(script);
Apabila call.js dimuatkan, kita perlu memanggil kaedah di dalamnya. Walau bagaimanapun, kami tidak boleh memanggil js serta-merta selepas header.appendChild(script). Oleh kerana penyemak imbas memuatkan js ini secara tidak segerak, kami tidak tahu bila ia telah selesai dimuatkan. Walau bagaimanapun, kita boleh menentukan sama ada helper.js dimuatkan dengan mendengar acara. (Andaikan terdapat kaedah panggil balik dalam call.js) Kodnya adalah seperti berikut:
var head= document.getElementsByTagName('head')[0]; var script= document.createElement('script'); script.type= 'text/javascript'; script.onreadystatechange= function () { if (this.readyState == 'complete') callback(); } script.onload= function(){ callback(); } script.src= 'helper.js'; head.appendChild(script);
Saya menyediakan 2 fungsi mendengar acara kerana onreadystatechange digunakan dalam IE, dan tokek, penyemak imbas webkit dan opera semuanya menyokong onload. Sebenarnya, this.readyState == 'lengkap' tidak berfungsi dengan baik Secara teorinya, perubahan keadaan adalah seperti berikut:
1.tidak dimulakan
2.memuatkan
3.dimuatkan
4.interaktif
5.lengkap
Tetapi beberapa negeri akan dilangkau. Mengikut pengalaman, dalam IE7, hanya satu daripada dimuatkan dan disiapkan boleh diperolehi, tetapi bukan kedua-duanya Sebabnya mungkin perubahan keadaan mempengaruhi sama ada bacaan daripada cache terjejas, atau mungkin sebab lain. Adalah lebih baik untuk menukar syarat penghakiman kepada this.readyState == 'loaded' || this.readyState == 'complete'
Merujuk kepada pelaksanaan jQuery, pelaksanaan terakhir kami ialah: Kodnya adalah seperti berikut:
var head= document.getElementsByTagName('head')[0]; var script= document.createElement('script'); script.type= 'text/javascript'; script.onload = script.onreadystatechange = function() { if (!this.readyState || this.readyState === "loaded" || this.readyState === "complete" ) { help(); // Handle memory leak in IE script.onload = script.onreadystatechange = null; } }; script.src= 'helper.js'; head.appendChild(script);
Situasi mudah lain ialah menulis panggilan help() pada penghujung helper.js, maka ia boleh dijamin bahawa help() boleh dipanggil secara automatik selepas helper.js dimuatkan, ia mesti seperti ini akhirnya bukan apl yang sesuai untuk anda.
Perkara tambahan yang perlu diberi perhatian:
1. Oleh kerana src teg skrip boleh mengakses sumber merentas domain, kaedah ini boleh mensimulasikan ajax dan menyelesaikan masalah akses merentas domain ajax.
2. Jika kod HTML yang dikembalikan oleh ajax mengandungi skrip, memasukkan innerHTML terus ke dalam dom tidak akan menjadikan skrip dalam HTML berfungsi. Selepas melihat sepintas lalu pada kod asal jQuery().html(html), jQuery juga menghuraikan parameter masuk terlebih dahulu, menanggalkan kod skrip dan mencipta tag skrip secara dinamik Kaedah html jQuery digunakan untuk menambah html ke dalam dom jika ia mengandungi skrip boleh dilaksanakan. Seperti:
Di atas ialah kaedah memuatkan fail JavaScript secara dinamik. Saya harap ia akan membantu pembelajaran semua orang.

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





Soalan dan penyelesaian yang sering ditanya untuk percetakan tiket kertas terma depan dalam pembangunan front-end, percetakan tiket adalah keperluan umum. Walau bagaimanapun, banyak pemaju sedang melaksanakan ...

Tidak ada gaji mutlak untuk pemaju Python dan JavaScript, bergantung kepada kemahiran dan keperluan industri. 1. Python boleh dibayar lebih banyak dalam sains data dan pembelajaran mesin. 2. JavaScript mempunyai permintaan yang besar dalam perkembangan depan dan stack penuh, dan gajinya juga cukup besar. 3. Faktor mempengaruhi termasuk pengalaman, lokasi geografi, saiz syarikat dan kemahiran khusus.

JavaScript adalah asas kepada pembangunan web moden, dan fungsi utamanya termasuk pengaturcaraan yang didorong oleh peristiwa, penjanaan kandungan dinamik dan pengaturcaraan tak segerak. 1) Pengaturcaraan yang didorong oleh peristiwa membolehkan laman web berubah secara dinamik mengikut operasi pengguna. 2) Penjanaan kandungan dinamik membolehkan kandungan halaman diselaraskan mengikut syarat. 3) Pengaturcaraan Asynchronous memastikan bahawa antara muka pengguna tidak disekat. JavaScript digunakan secara meluas dalam interaksi web, aplikasi satu halaman dan pembangunan sisi pelayan, sangat meningkatkan fleksibiliti pengalaman pengguna dan pembangunan silang platform.

Bagaimana cara menggabungkan elemen array dengan ID yang sama ke dalam satu objek dalam JavaScript? Semasa memproses data, kita sering menghadapi keperluan untuk mempunyai id yang sama ...

Perbincangan mengenai realisasi kesan animasi tatal dan elemen Parallax dalam artikel ini akan meneroka bagaimana untuk mencapai yang serupa dengan laman web rasmi Shiseido (https://www.shiseido.co.jp/sb/wonderland/) ... ...

Perbincangan mendalam mengenai punca-punca utama perbezaan dalam output konsol.log. Artikel ini akan menganalisis perbezaan hasil output fungsi Console.log dalam sekeping kod dan menerangkan sebab -sebab di belakangnya. � ...

Pembelajaran JavaScript tidak sukar, tetapi ia mencabar. 1) Memahami konsep asas seperti pembolehubah, jenis data, fungsi, dan sebagainya. 2) Pengaturcaraan asynchronous tuan dan melaksanakannya melalui gelung acara. 3) Gunakan operasi DOM dan berjanji untuk mengendalikan permintaan tak segerak. 4) Elakkan kesilapan biasa dan gunakan teknik debugging. 5) Mengoptimumkan prestasi dan mengikuti amalan terbaik.

Terokai pelaksanaan fungsi seretan panel dan drop panel seperti VSCode di bahagian depan. Dalam pembangunan front-end, bagaimana untuk melaksanakan vscode seperti ...
