国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

使javascript也能包含文件

2024-09-06 12:44:41
字體:
來源:轉載
供稿:網友

javascript功能強大,但一個問題是它不能包含其它的js文件,而其它非腳本語言卻基本都是有這個功能的,不得不覺得有點遺憾。窮則思變,越來越發現不動態導入文件會嚴重加大加載頁面的時間,經過實驗,發現了一個辦法,利用xhtml來實現這個功能,下面的函數就可以動態導入javascript文件和css樣式文件: 
代碼如下:
function $import(path,type,title){
 var s,i;
 if(type=="js"){
  var ss=document.getElementsByTagName("script");
  for(i=0;i<ss.length;i++){
   if(ss[i].src && ss[i].src.indexOf(path)!=-1)return;
  }
  s=document.createElement("script");
  s.type="text/javascript";
  s.src=path;
 }else if(type=="css"){
  var ls=document.getElementsByTagName("link");
  for(i=0;i<ls.length;i++){
   if(ls[i].href && ls[i].href.indexOf(path)!=-1)return;
  }
  s=document.createElement("link");
  s.rel="alternate stylesheet";
  s.type="text/css";
  s.href=path;
  s.title=title;
  s.disabled=false;
 }
 else return;
 var head=document.getElementsByTagName("head")[0];
 head.appendChild(s);
}

對于樣式文件,默認導入后是立即生效的,這有可能會導致和前面一種選定樣式效果重疊,造成混亂。所以在我的blog中是使用下面的函數來實現樣式的切換功能: 

代碼如下: 
function setStyle(title) {
 var i, links,eflag=false;
 links = document.getElementsByTagName("link");
 for(i=0; links[i]; i++) {
  if(links[i].getAttribute("rel").indexOf("style") != -1 && links[i].getAttribute("title")) {
   links[i].disabled = true;
   if(links[i].getAttribute("title").indexOf(title) != -1){links[i].disabled = false;eflag=true;}
  }
 }
 if(!eflag){
  $import("skin/"+title+"/default.css","css",title);
  setStyle(title);
 }
}


最后,說明一下,因為javascript文件是需要從遠程加載的,所以有人可能會問在調用$import()函數后,是立即執行$import()后面的語句,還是等加載完以后再執行其后的語句。我粗略試驗了一下,發現是等加載完后再執行后面的語句的,而且如果加載的js里有立即執行的代碼,那么它會先于$import()后面的語句執行。這也是我們想要的結果,因為這樣就可以在$import()之后調用加載的文件里的函數了。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 永新县| 江城| 镇康县| 江源县| 罗江县| 佛冈县| 南澳县| 岳西县| 和顺县| 绥江县| 翁源县| 绥德县| 青阳县| 曲靖市| 涞源县| 雷州市| 炉霍县| 石嘴山市| 田阳县| 科技| 巴里| 福鼎市| 资源县| 商城县| 通城县| 南丰县| 温州市| 西乌珠穆沁旗| 黄浦区| 偃师市| 包头市| 安顺市| 平原县| 黎城县| 雷山县| 翁牛特旗| 全椒县| 和林格尔县| 广昌县| 荥阳市| 忻州市|