時(shí)間轉(zhuǎn)換

該組件適用于以下場景

1深员,將時(shí)間戳轉(zhuǎn)換成時(shí)間顯示数苫,支持年,月辨液,日虐急,天,分滔迈,秒止吁,毫秒,可以定義自己想要的格式來顯示燎悍,比如2018-03-20 18:20/2018/03/20 19:20

2敬惦,將時(shí)間轉(zhuǎn)換成時(shí)間戳顯示,

3谈山,獲取兩個(gè)時(shí)間的時(shí)間差

4俄删,在日前前面加上0,比如:2018-3-12? => 2018-03-12

js源碼


let ts = 1000 * 60 * 60 * 24;? let xs = 1000 * 60 * 60;? let fz = 1000 * 60;? let hm = 1000;? let date_list = {}; // 緩存數(shù)據(jù)

/**

* [setTime 獲取時(shí)間差]

* @param {[時(shí)間格式]} start [開始時(shí)間]

* @param {[(可為空)時(shí)間格式]} end? [結(jié)束時(shí)間]

* @param {[(可為空)數(shù)值]} poor? [差(毫秒)]

*/

function setTime(start, end, poor) {

? ? let m = 0;

? ? let _key = start + '_' + end;

? ? /** [if 檢查相對(duì)應(yīng)‘毫秒差’是否已存在緩存中奏路,不存在則獲取數(shù)據(jù)并緩存] */

? ? if (!date_list[_key]) {

?????????if (typeof end === 'undefined') { m = start * 1;

? ? ? ? ? ????? if (!m && m != 0) {m = examine(start).getTime(); }

? ?????????} else { m = examine(end).getTime() - examine(start).getTime(); // 日期時(shí)間格式 }?

????????date_list[_key] = m;

? ? } else {? m = date_list[_key]; }

? ? m = m - ((m >= 0 ? poor : -poor) || 0);

? ? let _data = { day: '0', // 天? hour: '00', // 小時(shí)? ?min: '00', // 分鐘 sec: '00', // 秒 base: m || 0 // 毫秒 };

? ? /** 開始計(jì)算 */

? ? m = Math.abs(m);

? ? if (m > 0) { let day = (m / ts) >> 0;? ?let hour = ((m - day * ts) / xs) >> 0;? ?let min = ((m - day * ts - hour * xs) / fz) >> 0;

? ? ? ? let sec = ((m - day * ts - hour * xs - min * fz) / hm) >> 0;

? ? ? ? _data.day = patchZero(day, _data.day.length);

? ? ? ? _data.hour = patchZero(hour, _data.hour.length);

? ? ? ? _data.min = patchZero(min, _data.min.length);

? ? ? ? _data.sec = patchZero(sec, _data.sec.length); }

? ? return _data; }

/**

* [examine 轉(zhuǎn)換日期]

* @param? {[]} str [支持時(shí)間戳畴椰、時(shí)間格式、Date]

* @return {[Date]}? ? [Date]

*/

function examine(str) {

? ? try {? let _date;

? ? ? ? /** [if 判斷是否已經(jīng)為時(shí)間對(duì)象] */

? ? ? ? if (typeof str === 'object' && typeof str.getTime === 'function') {? ?return str;? ?}

? ? ? ? /** [if 判斷是否為時(shí)間戳格式] */

? ? ? ? if (str >> 0) {

? ? ? ? ? ? if ((str).toString().length == 10) {? str = str * 1000;? } else { str = str * 1;? }

? ? ? ? } else {

? ? ? ? ? ? /** 為了兼容坑爹的ios */

? ? ? ? ? ? str = str.replace(/-/g, '/');

? ? ? ? }

? ? ? ? /** [if 是否不為空] */

? ? ? ? if (str && str != '0') {

? ? ? ? ? ? _date = new Date(str);

? ? ? ? ? ? if (_date == 'Invalid Date') {? console.warn('日期格式錯(cuò)誤:', str);? }

?????????????else { return _date;? }

? ? ? ? } else {? console.warn('不能為空!');? ? }

? ? } catch (err) {? console.warn(err);? }

}

/**

* [getDate 獲取相對(duì)應(yīng)的年月日等]

* @param? {[時(shí)間]} date [時(shí)間戳鸽粉、時(shí)間格式字符串斜脂、]

* @param? {[字符串]} fmt? [編號(hào)成的時(shí)間格式,第一個(gè)為!時(shí)]

* @return {[對(duì)象]}? ? ? [description]

*/

function getDate(date, fmt = '!y-M-d h:m:s.S') {

? ? let _date = examine(date);

? ? if (_date) {? ?let _regfun;

? ? ? ? let o = {? ?'y': _date.getFullYear(), // 年份? ?'M': _date.getMonth() + 1, // 月份? 'd': _date.getDate(), // 日? ?'h': _date.getHours(), // 小時(shí)

? ? ? ? ? ? 'm': _date.getMinutes(), // 分? 's': _date.getSeconds(), // 秒? ?'q': Math.floor((_date.getMonth() + 3) / 3), // 季度

? ? ? ? ? ? 'S': _date.getMilliseconds() // 毫秒 };

? ? ? ? if (fmt.charAt(0) === '!') {? _regfun = patchZero; fmt = fmt.slice(1);

? ? ? ? ????} else { _regfun = function (a, l) {? ?return ('00000' + a).slice(-l); };

? ? ? ? }

? ? ? ? for (let k in o) {

? ? ? ? ? ? if (new RegExp('(' + k + '+)').test(fmt)) {? fmt = fmt.replace(? RegExp.$1, _regfun(o[k], RegExp.$1.length)? ); }

? ? ? ? }

? ? ? ? o.fmt = fmt;

? ? ? ? return o;? }

}

/**

* [patchZero 前面加0]

* @param? {[type]} a [description]

* @param? {[type]} l [description]

* @return {[type]}? [description]

*/

function patchZero(a, l) {

? ? for (let i = (a).toString().length; i < l; i++) {? a = '0' + a; };

? ? return a;

}

module.exports = {

? ? setTime: setTime,? // 獲取時(shí)間差

? ? getDate: getDate,? // 獲取相對(duì)應(yīng)的年月日等

? ? patchZero: patchZero, // 前面加0

? ? examine: examine? // 轉(zhuǎn)換日期

};


后續(xù)應(yīng)該會(huì)直接給個(gè)git鏈接的触机,現(xiàn)在現(xiàn)在簡書上練練手帚戳,不太怎么會(huì)寫文章,之后能力有所提升的話儡首,會(huì)在git上分享更多片任,更深的東西


示例

js命名為timeDeal.js

import?getDate from './timeDeal'

const currentData = +new Date(); // 獲取當(dāng)前時(shí)間戳

const time =?getDate( currentData? , 'yyyy.M.dd hh:mm').fmt

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市蔬胯,隨后出現(xiàn)的幾起案子对供,更是在濱河造成了極大的恐慌,老刑警劉巖笔宿,帶你破解...
    沈念sama閱讀 218,941評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件犁钟,死亡現(xiàn)場離奇詭異,居然都是意外死亡泼橘,警方通過查閱死者的電腦和手機(jī)涝动,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來炬灭,“玉大人醋粟,你說我怎么就攤上這事≈毓椋” “怎么了米愿?”我有些...
    開封第一講書人閱讀 165,345評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長鼻吮。 經(jīng)常有香客問我育苟,道長,這世上最難降的妖魔是什么椎木? 我笑而不...
    開封第一講書人閱讀 58,851評(píng)論 1 295
  • 正文 為了忘掉前任违柏,我火速辦了婚禮,結(jié)果婚禮上香椎,老公的妹妹穿的比我還像新娘漱竖。我一直安慰自己,他們只是感情好畜伐,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,868評(píng)論 6 392
  • 文/花漫 我一把揭開白布馍惹。 她就那樣靜靜地躺著,像睡著了一般玛界。 火紅的嫁衣襯著肌膚如雪万矾。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,688評(píng)論 1 305
  • 那天慎框,我揣著相機(jī)與錄音勤众,去河邊找鬼。 笑死鲤脏,一個(gè)胖子當(dāng)著我的面吹牛们颜,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播猎醇,決...
    沈念sama閱讀 40,414評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼窥突,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了硫嘶?” 一聲冷哼從身側(cè)響起阻问,我...
    開封第一講書人閱讀 39,319評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎沦疾,沒想到半個(gè)月后称近,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體第队,經(jīng)...
    沈念sama閱讀 45,775評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年刨秆,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了凳谦。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,096評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡衡未,死狀恐怖尸执,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情缓醋,我是刑警寧澤如失,帶...
    沈念sama閱讀 35,789評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站送粱,受9級(jí)特大地震影響褪贵,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜抗俄,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,437評(píng)論 3 331
  • 文/蒙蒙 一竭鞍、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧橄镜,春花似錦偎快、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至姊氓,卻和暖如春丐怯,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背翔横。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評(píng)論 1 271
  • 我被黑心中介騙來泰國打工读跷, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人禾唁。 一個(gè)月前我還...
    沈念sama閱讀 48,308評(píng)論 3 372
  • 正文 我出身青樓效览,卻偏偏與公主長得像,于是被迫代替她去往敵國和親荡短。 傳聞我的和親對(duì)象是個(gè)殘疾皇子丐枉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,037評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容