bootstrap datetimepicker 日期插件在火狐下出現(xiàn)一條報(bào)錯(cuò)信息的原因分析及解決辦法
日期插件 bootstrap-datetimepicker 在火狐下出現(xiàn)一條報(bào)錯(cuò)信息:TypeError: (intermediate value).toString(…).split(…)[1] is undefined
這條錯(cuò)誤必然出現(xiàn),難道沒有在 Firefox 下進(jìn)行測試。
在 Firefox 下查看項(xiàng)目 demo (http://www.malot.fr/bootstrap-datetimepicker/demo.php)可以正常運(yùn)行,但這個(gè) demo.php 使用的是 2013-3-2 的 datetimepicker,github 項(xiàng)目(https://github.com/smalot/bootstrap-datetimepicker/releases)已經(jīng)發(fā)布到 2017-3-3,這個(gè)最新的版本(以及最近的一些版本)在 Firefox 下測試不完善,計(jì)算 defaultTimeZone 時(shí)雖然沒有出錯(cuò),但給出的結(jié)果也不正確。
源代碼如下,運(yùn)行環(huán)境 Firefox 51.0.1(32位)
this.defaultTimeZone = (new Date).toString().split('(')[1].slice(0, -1); this.timezone = options.timezone || this.defaultTimeZone; // 2.4.4 改進(jìn)版本 this.timezone = options.timezone || timeZoneAbbreviation(); function timeZoneAbbreviation() { var abbreviation, date, formattedStr, i, len, matchedStrings, ref, str; date = (new Date()).toString(); formattedStr = ((ref = date.split('(')[1]) != null ? ref.slice(0, -1) : 0) || date.split(' '); if (formattedStr instanceof Array) { matchedStrings = []; for (var i = 0, len = formattedStr.length; i < len; i++) { str = formattedStr[i]; if ((abbreviation = (ref = str.match(/\b[A-Z]+\b/)) !== null) ? ref[0] : 0) { matchedStrings.push(abbreviation); } } formattedStr = matchedStrings.pop(); } return formattedStr; }
出錯(cuò)原因是 Firefox 下 Date.prototype.toString 返回結(jié)果不包含 TimeZone 的文字描述。
2.4.4 改進(jìn)版本使用的 timeZoneAbbreviation 函數(shù)在 Firefox 下返回 true
對(duì) timeZoneAbbreviation 使用的三元表達(dá)式依次簡化
((abbreviation = (ref = str.match(/\b[A-Z]+\b/)) !== null) ? ref[0] : 0) (abbreviation = (ref = str.match(/\b[A-Z]+\b/)) !== null) (abbreviation = (xxx) !== null) (abbreviation = xxx !== null) abbreviation 必然是布爾值,如果將 matchedStrings.push(abbreviation) 換成 matchedStrings.push(str) 更接近預(yù)期值。
推薦使用文末的方案。
解決方案
將 date toString 最后一個(gè)空格之后的字符串作為 TimeZone。
// this.defaultTimeZone = (new Date).toString().split('(')[1].slice(0, -1); this.defaultTimeZone = (new Date + '').split(' ').slice(-1)[0].replace(/\(|\)/g, ''); this.timezone = options.timezone || this.defaultTimeZone;
以上所述是小編給大家介紹的 bootstrap datetimepicker 日期插件在火狐下出現(xiàn)一條報(bào)錯(cuò)信息的原因分析及解決辦法,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
JS實(shí)現(xiàn)點(diǎn)擊按鈕可實(shí)現(xiàn)編輯功能
本文通過一段實(shí)例代碼給大家介紹了基于js實(shí)現(xiàn)點(diǎn)擊按鈕可編輯效果,代碼簡單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的的朋友參考下吧2018-07-07JS的Ajax與后端交互數(shù)據(jù)的實(shí)例
今天小編就為大家分享一篇JS的Ajax與后端交互數(shù)據(jù)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-08-08全面解析Bootstrap中form、navbar的使用方法
這篇文章主要為大家詳細(xì)解析了Bootstrap中form、navbar的使用方法,感興趣的朋友可以參考一下2016-05-05uniapp實(shí)現(xiàn)全局變量的幾種方式總結(jié)
這里說全局變量,著重指的是能夠全局動(dòng)態(tài)響應(yīng)的情況,下面這篇文章主要給大家介紹了關(guān)于uniapp實(shí)現(xiàn)全局變量的幾種方式,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-10-10- 向?qū)Э梢宰屇愕木W(wǎng)站用戶快速上手使用你的web應(yīng)用,提高網(wǎng)站的吸引力。向?qū)б话惴譃楹脦讉€(gè)步驟,每個(gè)步驟收集一些數(shù)據(jù),并且支持退回功能,所有步驟完成后可以得到每一步的收集結(jié)果。這里給大家展示一種比較通用,靈活且簡單的向?qū)Э蚣堋?/div> 2011-08-08
js與vue如何實(shí)現(xiàn)自動(dòng)全屏顯示效果
這篇文章主要給大家介紹了關(guān)于js與vue如何實(shí)現(xiàn)自動(dòng)全屏顯示效果的相關(guān)資料,在vue項(xiàng)目中做一個(gè)可以控制頁面全屏展示的效果,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12最新評(píng)論