淺析Javascript使用include/require
1. javascript include
Javascript 沒有 include 語(yǔ)句有時(shí)挺討厭, 特別是腳本和腳本之間存在依存的關(guān)系, 你根本就不能動(dòng)態(tài)的去控制加載腳本, 一般來(lái)說(shuō)最簡(jiǎn)單的 include 基本就是這樣的, 當(dāng)然我們這個(gè)使用了 jQuery 來(lái)進(jìn)行請(qǐng)求腳本.
include: function (jsurl) {
if (jsurl == null || typeof(jsurl) != 'string') return;
var js = document.createElement('script');
js.type = 'text/javascript';
js.charset = 'utf-8';
js.src = jsurl;
$.ajaxSetup({ cache : true });
$('head').append(js);
//$.getScript(jsurl);
}
基本用法
需要注意的是該函數(shù)其實(shí)在發(fā)送GET請(qǐng)求的事情是 jQuery.ajax 的 getScript() 來(lái)處理的, 但是在GET后的處理和 $.getScript() 不同, 因此導(dǎo)致使用方法會(huì)不一樣, getScript() 一般需要把有依賴的函數(shù)寫到它的回調(diào)函數(shù)中去, 如:
$.getScript('some.js', function() {
// 做寫依賴 some.js文件的事情.
});
而我們這里的 include 不需要這么寫, 而是直接:
include('some.js');
// 這里可以直接寫依賴 some.js 文件中定義的函數(shù)
開啟緩存
另外就是關(guān)于文件緩存, 默認(rèn)情況下 $.getScript 是會(huì)在 url 后面加上一個(gè)時(shí)間戳, 使得在第二次請(qǐng)求的時(shí)候不讓瀏覽器去讀取緩存文件, 如果我們 getScript("some.js") , 最后在請(qǐng)求的時(shí)候會(huì)變成 GET some.js?_23432434534235 之類的, 這是一種強(qiáng)制不緩存的策略, 在開發(fā)階段是比較好的, 但到了生產(chǎn)階段, 會(huì)導(dǎo)致用戶的瀏覽器每次都不緩存我們的js腳本, 這對(duì)效率是很大的影響, 我們應(yīng)該自己在js腳本后面自己加上版本戳, 比如 some.js?v=1 , 而不是使用每次都會(huì)變的時(shí)間戳, 所以需要使用:
$.ajaxSetup({ cache : true });
這樣就會(huì)關(guān)閉jQuery自動(dòng)在url后面加上時(shí)間戳的特性.
requireJs
如果你的腳本大量的存在互相依賴關(guān)系, 而又需要?jiǎng)討B(tài)的決定加載哪些腳本, 那么我推薦的是使用requirejs .
它的基本用法是:
require(["some/module", "a.js", "b.js"], function(someModule) {
// do something
});
它有一個(gè)要求就是你的前端js是作為模塊式的開發(fā), 在前端邏輯比較復(fù)雜的話, 使用模塊式來(lái)進(jìn)行前端開發(fā)應(yīng)該是種不錯(cuò)的選擇, 而關(guān)于JS的模塊式開發(fā)在今后文章再專門談, 這里只簡(jiǎn)單介紹一下, 如果對(duì)這個(gè)方面感興趣的可以到requireJs官網(wǎng)去看看.
相關(guān)文章
js實(shí)現(xiàn)敏感詞過濾算法及實(shí)現(xiàn)邏輯
這篇文章主要介紹了js實(shí)現(xiàn)敏感詞過濾算法及實(shí)現(xiàn)邏輯,文中介紹了dfa算法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-07-07基于JS實(shí)現(xiàn)table導(dǎo)出Excel并保留樣式
這篇文章主要介紹了基于JS實(shí)現(xiàn)table導(dǎo)出Excel并保留樣式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05layui點(diǎn)擊左側(cè)導(dǎo)航欄,實(shí)現(xiàn)不刷新整個(gè)頁(yè)面,只刷新局部的方法
今天小編就為大家分享一篇layui點(diǎn)擊左側(cè)導(dǎo)航欄,實(shí)現(xiàn)不刷新整個(gè)頁(yè)面,只刷新局部的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2019-09-09electron-builder 的基本使用及electron打包步驟
electron-builder 作為一個(gè)用于 Electron 應(yīng)用程序打包的工具,需要下載并使用 Electron 運(yùn)行時(shí)來(lái)創(chuàng)建可執(zhí)行文件,這篇文章主要介紹了electron-builder 的基本使用,需要的朋友可以參考下2023-12-12