最近在使用 jQuery 的 load 方法加載 js 文件的時(shí)候,出現(xiàn)了一些問(wèn)題。
本來(lái)以為這個(gè)方法非常簡(jiǎn)單,只需要在需要加載 js 的元素上調(diào)用 load 方法,然后在其回調(diào)函數(shù)中執(zhí)行 js 代碼就可以了。但是當(dāng)我試圖使用這個(gè)方法的時(shí)候,發(fā)現(xiàn) js 代碼并沒(méi)有被執(zhí)行。
$("#my-div").load("my-script.js", function() {
console.log("this message should be printed");
});
經(jīng)過(guò)一番查找資料和排查代碼,我終于找到了問(wèn)題所在。原來(lái)在使用 load 方法加載 js 文件的時(shí)候,是無(wú)法直接執(zhí)行其中的代碼的。load 方法只是把 js 文件的內(nèi)容加載到了指定元素中,并不能讓其中的代碼自動(dòng)執(zhí)行。
那么應(yīng)該如何解決這個(gè)問(wèn)題呢?其實(shí)解決方法也很簡(jiǎn)單,只需要在加載 js 文件的回調(diào)函數(shù)中手動(dòng)調(diào)用一下其中的代碼就可以了。
$("#my-div").load("my-script.js", function() {
$.getScript("my-script.js");
});
這樣就可以成功地加載并執(zhí)行 js 文件中的代碼了。
總之,雖然遇到了這個(gè)小問(wèn)題,但是通過(guò)解決它,我對(duì) jQuery 的 load 方法以及 js 文件的加載和執(zhí)行有了更深入的了解,收獲不少。