jquery UI Datepicker時間控件沖突問題解決
公司里的項目由于發(fā)展較快,很多東西都沒有好好梳理一下,以至于有很多的潛在的問題。
最近就遇到了一個比較坑的問題。datepicker
有兩個插件庫中的datepicker插件比較有名。一個是jQuery-UI,一個是bootstrap。兩個的api網(wǎng)址分別是
然而在項目中很不巧的兩個庫都用到了。然后就出現(xiàn)了以下情況:http://jqueryui.com/datepicker/ 和 http://bootstrap-datepicker.readthedocs.io/en/latest/index.html
平時根本不知道我自己用的到底是哪個組件。
主要的問題是,要是你們兩個組件能一樣的話,我也就沒什么問題了。兩個組件在各種細節(jié)處完全不同。
這次的問題是 我的datepicker框被遮住了,具體如下圖(上面的年份切換不見了):
找了一下發(fā)現(xiàn)是在渲染組件的時候,給自動的加上了z-index:10,然后就被上面fixed的頂部條給遮住了。然而這種情況并不是必現(xiàn)的,在每個人電腦上出現(xiàn)的情況不同,在我看來就是先加載的是誰的組件造成的。(按理來說項目打包后是按照index.html文件中引用的順序排的,應(yīng)該也是相同的調(diào)用順序,但是就是在一部分電腦上會出現(xiàn)順序反過來。有大神能解答么?)
于是為了確定加載的是哪個,我寫了下面的代碼進行試驗:
// 初始化日期控件 var $buyDate = $("input#abc"); var buyDateDatepicker = $buyDate.datepicker({ language: "zh-CN", format: "yyyymm", minViewMode: "months", autoclose: true, onSelect: function() { console.log("a"); }, onClose: function() { console.log("b"); } }); $buyDate.on("show", function() { $(".datepicker.datepicker-dropdown.dropdown-menu").css("z-index", 1000); });
這其中大多數(shù)都是公用的,其中onSelect、onClose是jQuery-UI的,on綁定的show事件是bootstrap的。
但是跑了一下之后,讓我比較吃驚,一個都沒有執(zhí)行,全都沒有用。然后靜下來仔細考慮了一下,應(yīng)該是這樣。
1、先執(zhí)行的是bootstrap的組件,先渲染了一遍。
2、然后又讓jQuery-UI渲染了一遍,但是并沒有覆蓋之前的組件。
3、再執(zhí)行了show事件的綁定。然而這個時候被jQuery-UI重新渲染過了,是讀取不到監(jiān)聽事件的,隨意也失效了。
我估計,在別人的電腦上,情況反了過來,他們先執(zhí)行的是jQuery-UI的組件就是可以的。
我在網(wǎng)上都沒有查到過其他的人寫過相關(guān)的沖突的情況。有沒有人遇到過,提供一下坑。以后避免踩坑。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Laravel admin實現(xiàn)消息提醒、播放音頻功能
這篇文章主要介紹了Laravel admin實現(xiàn)消息提醒、播放音頻功能,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-07-07jQuery+Ajax+js實現(xiàn)請求json格式數(shù)據(jù)并渲染到html頁面操作示例
這篇文章主要介紹了jQuery+Ajax+js實現(xiàn)請求json格式數(shù)據(jù)并渲染到html頁面操作,結(jié)合實例形式分析了jQuery+Ajax請求json格式數(shù)據(jù)并渲染到html頁面相關(guān)步驟與操作技巧,需要的朋友可以參考下2020-06-06jQuery插件HighCharts繪制簡單2D折線圖效果示例【附demo源碼】
這篇文章主要介紹了jQuery插件HighCharts繪制簡單2D折線圖效果,結(jié)合完整實例形式分析了jQuery使用HighCharts插件繪制折線圖的實現(xiàn)步驟與相關(guān)操作技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-03-03JQuery通過AJAX從后臺獲取信息顯示在表格上并支持行選中
這篇文章主要介紹了JQuery通過AJAX從后臺獲取信息顯示在表格上并支持行選中的相關(guān)資料,需要的朋友可以參考下2015-09-09jquery網(wǎng)頁日歷顯示控件calendar3.1使用詳解
這篇文章主要為大家詳細介紹了jquery網(wǎng)頁日歷顯示控件calendar3.1使用,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-11-11騰訊與新浪的通過IP地址獲取當(dāng)前地理位置(省份)的接口
通過IP地址獲取當(dāng)前地理位置(省份)的接口,方便大家可以直接使用結(jié)合自己的系統(tǒng)。2010-07-07jQuery學(xué)習(xí)筆記之Ajax用法實例詳解
這篇文章主要介紹了jQuery學(xué)習(xí)筆記之Ajax用法,結(jié)合實例形式較為詳細的分析總結(jié)了jQuery中ajax的相關(guān)使用技巧,包括ajax請求、載入、處理、傳遞等,需要的朋友可以參考下2015-12-12使用jquery的jsonp如何發(fā)起跨域請求及其原理詳解
JSONP是一個非官方的協(xié)議,它允許在服務(wù)器端集成Script tags返回至客戶端,通過JavaScript callback的形式實現(xiàn)跨域訪問(這僅僅是JSONP簡單的實現(xiàn)形式)。下面這篇文章主要給大家介紹了關(guān)于使用jquery的jsonp如何發(fā)起跨域請求及其原理的相關(guān)資料,需要的朋友可以參考下。2017-08-08