Rumah hujung hadapan web tutorial js Dua cara untuk memuatkan fail JavaScript_petua javascript secara dinamik

Dua cara untuk memuatkan fail JavaScript_petua javascript secara dinamik

May 16, 2016 pm 03:04 PM

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 <skrip src="...">< di kepala. /script>, tetapi teg skrip ini dibuat dengan animasi js
Contohnya, jika kami ingin memuatkan callbakc.js secara dinamik, kami memerlukan teg skrip sedemikian:
Kodnya adalah seperti berikut:

Salin kod Kod adalah seperti berikut:
<script type="text/javascript" src="call. js"> ;</script>

Kod berikut ialah cara membuat teg ini melalui js (dan tambahkannya pada kepala):
Kodnya adalah seperti berikut:

1

2

3

4

5

var head= document.getElementsByTagName('head')[0];

var script= document.createElement('script');

script.type= 'text/javascript';

script.src= 'call.js';

head.appendChild(script);

Salin selepas log masuk

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:

1

2

3

4

5

6

7

8

9

10

11

12

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);

Salin selepas log masuk

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:

1

2

3

4

5

6

7

8

9

10

11

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);

Salin selepas log masuk

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:

Salin kod Kod adalah seperti berikut:
jQuery("#content").html("<script> alert(' aa');</script>");

Di atas ialah kaedah memuatkan fail JavaScript secara dinamik. Saya harap ia akan membantu pembelajaran semua orang.

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Tag artikel panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Ganti aksara rentetan dalam javascript Ganti aksara rentetan dalam javascript Mar 11, 2025 am 12:07 AM

Ganti aksara rentetan dalam javascript

periksa jQuery jika tarikh sah periksa jQuery jika tarikh sah Mar 01, 2025 am 08:51 AM

periksa jQuery jika tarikh sah

jQuery mendapatkan padding/margin elemen jQuery mendapatkan padding/margin elemen Mar 01, 2025 am 08:53 AM

jQuery mendapatkan padding/margin elemen

10 Tab Accordion JQuery 10 Tab Accordion JQuery Mar 01, 2025 am 01:34 AM

10 Tab Accordion JQuery

10 patut diperiksa plugin jQuery 10 patut diperiksa plugin jQuery Mar 01, 2025 am 01:29 AM

10 patut diperiksa plugin jQuery

HTTP Debugging dengan Node dan HTTP-Console HTTP Debugging dengan Node dan HTTP-Console Mar 01, 2025 am 01:37 AM

HTTP Debugging dengan Node dan HTTP-Console

jQuery tambah bar scroll ke div jQuery tambah bar scroll ke div Mar 01, 2025 am 01:30 AM

jQuery tambah bar scroll ke div

Tutorial Persediaan API Carian Google Custom Tutorial Persediaan API Carian Google Custom Mar 04, 2025 am 01:06 AM

Tutorial Persediaan API Carian Google Custom

See all articles