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.