欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS 實現(xiàn)完美include載入實現(xiàn)代碼

 更新時間:2010年08月05日 13:29:16   作者:  
在寫這個之前在網(wǎng)上搜索了些資料,發(fā)現(xiàn)以前寫的include都存在2個問題,這也是include需要解決的比較重要的2個問題。
js為什么需要include?讓我們想想這樣1個場景,a.js 需要用到1個公用的common.js,當(dāng)然你可以在用到a.js的頁面使用<script src="common.js">,但假設(shè)有5個頁面用到了a.js,你是不是要寫5遍<script。而且要是以后a.js 又需要引用common2.js,你是不是又的修改5個頁面了?
已有js include的一些問題
  在寫這個之前在網(wǎng)上搜索了些資料,發(fā)現(xiàn)以前寫的include都存在2個問題,這也是include需要解決的比較重要的2個問題。
  1、相對路徑的問題: 在a.js中使用include("../js/common.js"); include 函數(shù)中肯定是使用相對路徑,是相對a.js的路徑。而a.js在html中使用<script>嵌入有可能是相對路徑,有可能是絕對路徑。 include函數(shù)如何才能真正確定common.js的絕對路徑,或者是相對html的相對路徑。網(wǎng)上一些為了解決這個問題,還需要加一些js變量,不方便。
  2、引用的問題。 網(wǎng)上include函數(shù)的實現(xiàn)幾乎都是使用下面2種方式插入common.js
      document.write("<script src='" + .. + "></script>")
    或者
      var s = document.createElement("script");
      s.src = ...;
      head.insertAfter(s,...);
    document.write 輸出的腳本會在a.js后面加載,而createElement("script")創(chuàng)建的腳本是非阻塞加載。 所以如果在common.js加載完畢之前,a.js中調(diào)用了common.js的函數(shù)就會報錯。
實現(xiàn)
  解決上面2個問題,就可以實現(xiàn)js include。
  第1個問題,我的方法是先獲取到a.js在html中的絕對路徑(如果是相對路徑,就轉(zhuǎn)為絕對路徑),然后再把common.js的路徑轉(zhuǎn)為絕對路徑。
  第2個問題,采用同步的ajax來請求common.js,這樣就不會出現(xiàn)引用問題。
  實現(xiàn)代碼如下:
復(fù)制代碼 代碼如下:

// 根據(jù)相對路徑獲取絕對路徑
function getPath(relativePath,absolutePath){
var reg = new RegExp("\\.\\./","g");
var uplayCount = 0; // 相對路徑中返回上層的次數(shù)。
var m = relativePath.match(reg);
if(m) uplayCount = m.length;
var lastIndex = absolutePath.length-1;
for(var i=0;i<=uplayCount;i++){
lastIndex = absolutePath.lastIndexOf("/",lastIndex);
}
return absolutePath.substr(0,lastIndex+1) + relativePath.replace(reg,"");
}
function include(jssrc){
// 先獲取當(dāng)前a.js的src。a.js中調(diào)用include,直接獲取最后1個script標(biāo)簽就是a.js的引用。
var scripts = document.getElementsByTagName("script");
var lastScript = scripts[scripts.length-1];
var src = lastScript.src;
if(src.indexOf("http://")!=0 && src.indexOf("/") !=0){
// a.js使用相對路徑,先替換成絕對路徑
var url = location.href;
var index = url.indexOf("?");
if(index != -1){
url = url.substring(0, index-1);
}
src = getPath(src,url);
}
var jssrcs = jssrc.split("|"); // 可以include多個js,用|隔開
for(var i=0;i<jssrcs.length;i++){
// 使用juqery的同步ajax加載js.
// 使用document.write 動態(tài)添加的js會在當(dāng)前js的后面,可能會有js引用問題
// 動態(tài)創(chuàng)建script腳本,是非阻塞下載,也會出現(xiàn)引用問題
$.ajax({type:'GET',url:getPath(jssrc,src),async:false,dataType:'script'});
}
}

在a.js中直接使用 include("../js/common.js");

多請求的問題
  使用上面的include看上去挺爽的,不過卻帶來另外1個嚴(yán)重的問題,就是多發(fā)送了1個ajax的請求。
  我們常常為了WEB性能,而合并js,減少請求。但使用include后卻偏偏多了請求。如果這個問題不解決,相信很多人都不會在正式產(chǎn)品中使用include的了,除非是局域網(wǎng)產(chǎn)品。

  如何解決這個多請求的問題,我也思考很久,最后覺的單單使用客戶端js是沒辦法解決了。所以就想到了使用服務(wù)端代碼來解決
  還記的我之前有文章介紹 "js、css的合并、壓縮、緩存管理"的時候,就通過服務(wù)器端代碼在程序啟動時候去合并js。

  所以我把include多請求的解決方案也加到里面去。就是在程序啟動的時候去查找所有的js,發(fā)現(xiàn)有使用include的就把include中common.js的源代碼替換該include函數(shù)。這樣a.js中在運行的時候就沒有include函數(shù),而是真真包含了common.js的內(nèi)容的js文件

后語
  丫的。說到最后,怎么又把所有的include都替換掉了,哪之前說的那么多不白說了。

  個人覺得,每個產(chǎn)品都應(yīng)該要區(qū)分開發(fā)環(huán)境和產(chǎn)品環(huán)境(一般通過配置文件進(jìn)行區(qū)分),在開發(fā)環(huán)境應(yīng)該以開發(fā)效率為首要,而產(chǎn)品環(huán)境則以性能為首。所以這里的inlcude就應(yīng)該要區(qū)分對待,在開發(fā)環(huán)境中使用js include來提高開發(fā)和維護(hù)效率,而在產(chǎn)品環(huán)境中則自動把所有include替換成真真的js文件的內(nèi)容。
[作者]:BearRui(AK-47)

相關(guān)文章

  • JavaScript自定義事件介紹

    JavaScript自定義事件介紹

    很多DOM對象都有原生的事件支持,向div就有click、mouseover等事件,事件機(jī)制可以為類的設(shè)計帶來很大的靈活性,相信.net程序員深有體會。隨著web技術(shù)發(fā)展,使用JavaScript自定義對象愈發(fā)頻繁,讓自己創(chuàng)建的對象也有事件機(jī)制,通過事件對外通信,能夠極大提高開發(fā)效率
    2013-08-08
  • ES6中javascript實現(xiàn)函數(shù)綁定及類的事件綁定功能詳解

    ES6中javascript實現(xiàn)函數(shù)綁定及類的事件綁定功能詳解

    這篇文章主要介紹了ES6中javascript實現(xiàn)函數(shù)綁定及類的事件綁定功能,結(jié)合實例形式分析了ES6中函數(shù)綁定及類的事件綁定原理、實現(xiàn)方法、相關(guān)操作技巧與注意事項,需要的朋友可以參考下
    2017-11-11
  • 禁止iframe頁面的所有js腳本如alert及彈出窗口等

    禁止iframe頁面的所有js腳本如alert及彈出窗口等

    一個頁面里面需要放一個iframe框架來預(yù)覽網(wǎng)站,可是被預(yù)覽的這個網(wǎng)站中含有很多js腳本,于是想禁止iframe里面的腳本,下面是方法
    2014-09-09
  • js時間戳格式化成日期格式的多種方法介紹

    js時間戳格式化成日期格式的多種方法介紹

    本篇文章主要介紹了js時間戳格式化成日期格式的多種方法介紹的資料,這里整理了詳細(xì)的代碼,有需要的小伙伴可以參考下。
    2017-02-02
  • 判斷及設(shè)置瀏覽器全屏模式

    判斷及設(shè)置瀏覽器全屏模式

    這篇文章主要介紹了如何判斷及設(shè)置瀏覽器全屏模式,需要的朋友可以參考下
    2014-04-04
  • Jquery 切換不同圖片示例代碼

    Jquery 切換不同圖片示例代碼

    切換不同圖片的方法有很多,在本文為大家介紹下使用jquery是如何做到的
    2013-12-12
  • 微信小程序?qū)崿F(xiàn)音樂播放器

    微信小程序?qū)崿F(xiàn)音樂播放器

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)音樂播放器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-11-11
  • JavaScript面向?qū)ο蟮某绦蛟O(shè)計(犯迷糊的小羊)

    JavaScript面向?qū)ο蟮某绦蛟O(shè)計(犯迷糊的小羊)

    這篇文章主要介紹了JavaScript面向?qū)ο蟮某绦蛟O(shè)計(犯迷糊的小羊),需要的朋友可以參考下
    2018-05-05
  • JS中的作用域鏈

    JS中的作用域鏈

    本文主要介紹了JS中的作用域鏈的相關(guān)知識。具有很好的參考價值,下面跟著小編一起來看下吧
    2017-03-03
  • ionic實現(xiàn)下拉刷新載入數(shù)據(jù)功能

    ionic實現(xiàn)下拉刷新載入數(shù)據(jù)功能

    這篇文章主要為大家詳細(xì)介紹了ionic實現(xiàn)下拉刷新載入數(shù)據(jù)功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05

最新評論