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()之后調用加載的文件里的函數了。
新聞熱點
疑難解答