亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

關(guān)于laydate.js加載laydate.css路徑錯誤問題解決

 更新時間:2017年12月27日 09:50:55   作者:e起飛  
日期時間選擇插件 laydate.js相信對大家來說都不陌生,這篇文章主要給大家介紹了關(guān)于laydate.js加載laydate.css路徑錯誤問題解決的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。

前言

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

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

laydate.js是通過ocLazyLoad異步加載引入的,結(jié)果始終加載不出來laydate.css文件,看了下路徑錯誤,于是扒開代碼發(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的那一截最終拼接成一個完整的路徑。

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

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

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

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

最終還是使用了下面這種簡單粗暴的方法:

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)行判斷截取即可。但這種辦法有以下兩個缺點(diǎn):

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

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

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • 2020京東618疊蛋糕js腳本(親測好用)

    2020京東618疊蛋糕js腳本(親測好用)

    這篇文章主要介紹了京東618疊蛋糕js腳本,基于auto.js 打開,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • JS 跳轉(zhuǎn)頁面延遲2種方法

    JS 跳轉(zhuǎn)頁面延遲2種方法

    js跳轉(zhuǎn)頁面想必大家不會很陌生吧,在瀏覽頁面的時候經(jīng)常會碰到這種現(xiàn)象存在如果可以延遲的話是不是會更委婉一點(diǎn)呢,接下來為大家介紹下如何實(shí)現(xiàn),感興趣的朋友可以參考下哈
    2013-03-03
  • 淺談es6語法 (Proxy和Reflect的對比)

    淺談es6語法 (Proxy和Reflect的對比)

    下面小編就為大家?guī)硪黄獪\談es6語法 (Proxy和Reflect的對比)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • js控制表單不能輸入空格的小例子

    js控制表單不能輸入空格的小例子

    這篇文章主要介紹了js控制表單不能輸入空格的小例子,有需要的朋友可以參考一下
    2013-11-11
  • javascript在myeclipse中報錯的解決方法

    javascript在myeclipse中報錯的解決方法

    jqueryjQueryJQUERYJqueryJQueryjquery報錯jsJSJsmyeclipseMyEclipseMyeclipse,很多朋友應(yīng)該都會遇到過這個情況吧,按照下面的步驟便可迎刃而解
    2013-10-10
  • 解析js原生方法創(chuàng)建表格效率測試

    解析js原生方法創(chuàng)建表格效率測試

    對于創(chuàng)建表格本文提到的算法共有3種,分別是直接操作dom、借助createDocumentFragment、借助js的原生表格操作方法
    2013-07-07
  • JavaScript實(shí)現(xiàn)圖片放大鏡效果

    JavaScript實(shí)現(xiàn)圖片放大鏡效果

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)圖片放大鏡效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-06-06
  • 兼容ie ff div 層 打開+關(guān)閉+ 拖動+遮罩+移動+動畫改變高寬

    兼容ie ff div 層 打開+關(guān)閉+ 拖動+遮罩+移動+動畫改變高寬

    div層 打開+關(guān)閉+ 拖動+遮罩+移動+動畫改變高寬的實(shí)例js代碼
    2008-07-07
  • 簡單了解Ajax表單序列化的實(shí)現(xiàn)方法

    簡單了解Ajax表單序列化的實(shí)現(xiàn)方法

    這篇文章主要介紹了簡單了解Ajax表單序列化的實(shí)現(xiàn)方法,隨著Ajax的出現(xiàn),表單序列化已經(jīng)成為一種需求,在學(xué)習(xí)原生Ajax時,若用POST方法向后臺提交數(shù)據(jù)時,就需要將表單序列化,需要的朋友可以參考下
    2019-06-06
  • 關(guān)于layui表單中按鈕自動提交的解決方法

    關(guān)于layui表單中按鈕自動提交的解決方法

    今天小編就為大家分享一篇關(guān)于layui表單中按鈕自動提交的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09

最新評論