中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

如何解決laydate.js加載laydate.css路徑錯(cuò)誤問題-創(chuàng)新互聯(lián)

小編給大家分享一下如何解決laydate.js加載laydate.css路徑錯(cuò)誤問題,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯(lián)公司是一家專業(yè)提供簡(jiǎn)陽(yáng)企業(yè)網(wǎng)站建設(shè),專注與成都做網(wǎng)站、成都網(wǎng)站建設(shè)、html5、小程序制作等業(yè)務(wù)。10年已為簡(jiǎn)陽(yáng)眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)絡(luò)公司優(yōu)惠進(jìn)行中。

前言

laydate.js是屬于Javascript系列的一款日期控件與時(shí)間插件,laydate.js支持兼容IE6在內(nèi)的主流瀏覽器。laydate.js經(jīng)過(guò)賢心大大的重寫之后功能越來(lái)越強(qiáng)大,用起來(lái)也愈漸靈活了,但是在一個(gè)基于angular+ocLazyLoad的項(xiàng)目中出了點(diǎn)問題。

發(fā)現(xiàn)問題

laydate.js是通過(guò)ocLazyLoad異步加載引入的,結(jié)果始終加載不出來(lái)laydate.css文件,看了下路徑錯(cuò)誤,于是扒開代碼發(fā)現(xiàn)是這樣寫的:

getPath:function(){
 var e=document.scripts,
 t=e[e.length-1],
 n=t.src;
 if(!t.getAttribute("merge"))
 return n.substring(0,n.lastIndexOf("/")+1)
}()

它是需要先獲取到laydate.js的路徑,然后再加上laydate.css的那一截最終拼接成一個(gè)完整的路徑。

作者用的獲取laydate.js路徑的思路是:由于判斷路徑的js代碼一般都直接放在js文件中而不是函數(shù)中,所以當(dāng)加載該js文件時(shí)會(huì)立即執(zhí)行其中的語(yǔ)句,而執(zhí)行此語(yǔ)句時(shí)所獲取到的js文件數(shù)目正好是e.length-1,因?yàn)轫?yè)面后面的js文件還沒有加載,所以該處的js文件獲取的數(shù)目并不是頁(yè)面所有的js文件的數(shù)目。這樣一來(lái),獲取路徑就無(wú)需再遍歷了,而且文件判斷也無(wú)需文件名,判斷更加準(zhǔn)確(e.length-1永遠(yuǎn)都是其文件本身)。

但是這種方法有缺陷,直接在html頁(yè)面中用script標(biāo)簽引入沒得問題,如果通過(guò)document.write("<script src='*.js'></script")document.createElement("script")動(dòng)態(tài)加載亦或者異步加載等得到的路徑卻是最后一個(gè)js文件的路徑,而非當(dāng)前j文件的路徑。

于是想起了document.currentScript ,一步就能到位,但是存在一定的兼容性問題。

var curSrc = document.currentScript.src;
return curSrc.substring(0,curSrc.lastIndexOf("/")+1);

最終還是使用了下面這種簡(jiǎn)單粗暴的方法:

getPath:function(){
 var e=document.scripts, n;
 for(var i=e.length;i>0;i--){
 if(e[i-1].src.indexOf("laydate.js")>-1){
 n=e[i-1].src.substring(0,e[i-1].src.lastIndexOf("/")+1);
 }
 }
 return n;
}()

這種方法的思路很清晰,根據(jù)文件名獲取引用的文件的src屬性并進(jìn)行判斷截取即可。但這種辦法有以下兩個(gè)缺點(diǎn):

1、需要遍歷頁(yè)面的所有js文件,有時(shí)可能效率會(huì)比較低。(我頁(yè)面的js文件沒幾個(gè),哈哈)

2、如果頁(yè)面中出現(xiàn)目錄不同的重名的js文件則可能判斷錯(cuò)誤。

以上是“如何解決laydate.js加載laydate.css路徑錯(cuò)誤問題”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

本文名稱:如何解決laydate.js加載laydate.css路徑錯(cuò)誤問題-創(chuàng)新互聯(lián)
URL標(biāo)題:http://www.rwnh.cn/article12/ccehgc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、商城網(wǎng)站網(wǎng)站導(dǎo)航、面包屑導(dǎo)航網(wǎng)站內(nèi)鏈、網(wǎng)站策劃

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)
荣成市| 临西县| 织金县| 安徽省| 大埔区| 宜川县| 柳林县| 通州市| 庄河市| 青州市| 纳雍县| 漯河市| 涞源县| 奉贤区| 望谟县| 沁水县| 新田县| 多伦县| 茶陵县| 石首市| 攀枝花市| 平果县| 东乌珠穆沁旗| 通城县| 丰台区| 黄梅县| 曲水县| 保亭| 康平县| 和林格尔县| 东乌珠穆沁旗| 康平县| 扎兰屯市| 依安县| 克什克腾旗| 开江县| 波密县| 修水县| 油尖旺区| 百色市| 成安县|