欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

bootstrap datetimepicker 日期插件在火狐下出現(xiàn)一條報(bào)錯(cuò)信息的原因分析及解決辦法

 更新時(shí)間:2017年03月08日 10:53:40   作者:袖之歡  
日期插件 bootstrap-datetimepicker 在火狐下出現(xiàn)一條報(bào)錯(cuò)信息:TypeError: (intermediate value).toString(…).split(…)[1] is undefined.什么原因?qū)е碌哪兀旅嫘【幗o大家分享解決思路,需要的朋友參考下

日期插件 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)編輯功能

    JS實(shí)現(xiàn)點(diǎn)擊按鈕可實(shí)現(xiàn)編輯功能

    本文通過一段實(shí)例代碼給大家介紹了基于js實(shí)現(xiàn)點(diǎn)擊按鈕可編輯效果,代碼簡單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的的朋友參考下吧
    2018-07-07
  • JS的Ajax與后端交互數(shù)據(jù)的實(shí)例

    JS的Ajax與后端交互數(shù)據(jù)的實(shí)例

    今天小編就為大家分享一篇JS的Ajax與后端交互數(shù)據(jù)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • js上傳圖片預(yù)覽的實(shí)現(xiàn)方法

    js上傳圖片預(yù)覽的實(shí)現(xiàn)方法

    這篇文章主要為大家詳細(xì)介紹了js上傳圖片預(yù)覽的實(shí)現(xiàn)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • 全面解析Bootstrap中form、navbar的使用方法

    全面解析Bootstrap中form、navbar的使用方法

    這篇文章主要為大家詳細(xì)解析了Bootstrap中form、navbar的使用方法,感興趣的朋友可以參考一下
    2016-05-05
  • uniapp實(shí)現(xiàn)全局變量的幾種方式總結(jié)

    uniapp實(shí)現(xiàn)全局變量的幾種方式總結(jié)

    這里說全局變量,著重指的是能夠全局動(dòng)態(tài)響應(yīng)的情況,下面這篇文章主要給大家介紹了關(guān)于uniapp實(shí)現(xiàn)全局變量的幾種方式,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-10-10
  • 用javascript作一個(gè)通用向?qū)дf明

    用javascript作一個(gè)通用向?qū)дf明

    向?qū)Э梢宰屇愕木W(wǎng)站用戶快速上手使用你的web應(yīng)用,提高網(wǎng)站的吸引力。向?qū)б话惴譃楹脦讉€(gè)步驟,每個(gè)步驟收集一些數(shù)據(jù),并且支持退回功能,所有步驟完成后可以得到每一步的收集結(jié)果。這里給大家展示一種比較通用,靈活且簡單的向?qū)Э蚣堋?/div> 2011-08-08
  • zTree插件下拉樹使用入門教程

    zTree插件下拉樹使用入門教程

    這篇文章主要為大家詳細(xì)介紹了zTree插件下拉樹使用入門教程,感興趣的小伙伴們可以參考一下
    2016-04-04
  • 一文看懂JSONP原理和應(yīng)用

    一文看懂JSONP原理和應(yīng)用

    這篇文章主要介紹了一文看懂JSONP原理和應(yīng)用,對(duì)JSONP感興趣的同學(xué),可以參考下
    2021-04-04
  • js與vue如何實(shí)現(xiàn)自動(dòng)全屏顯示效果

    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
  • JavaScript操作元素教你改變頁面內(nèi)容樣式

    JavaScript操作元素教你改變頁面內(nèi)容樣式

    這篇文章主要為大家介紹了JavaScript操作元素,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11

最新評(píng)論