From 231790da62af0494732960c2c50d86ae9bf63ec6 Mon Sep 17 00:00:00 2001 From: iamkun Date: Mon, 3 Aug 2020 16:56:18 +0800 Subject: [PATCH] fix: fix parse date string error e.g. '2020/9/30' (#980) fix #979 --- src/constant.js | 2 +- test/parse.test.js | 10 ++++++++++ 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/src/constant.js b/src/constant.js index b253c74e9..6cab7bee5 100644 --- a/src/constant.js +++ b/src/constant.js @@ -26,5 +26,5 @@ export const FORMAT_DEFAULT = 'YYYY-MM-DDTHH:mm:ssZ' export const INVALID_DATE_STRING = 'Invalid Date' // regex -export const REGEX_PARSE = /^(\d{4})-?(\d{1,2})?-?(\d{0,2})[^0-9]*(\d{1,2})?:?(\d{1,2})?:?(\d{1,2})?.?(\d{1,3})?$/ +export const REGEX_PARSE = /^(\d{4})[-/]?(\d{1,2})?[-/]?(\d{0,2})[^0-9]*(\d{1,2})?:?(\d{1,2})?:?(\d{1,2})?.?(\d{1,3})?$/ export const REGEX_FORMAT = /\[([^\]]+)]|Y{2,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g diff --git a/test/parse.test.js b/test/parse.test.js index e84a24417..6302d8942 100644 --- a/test/parse.test.js +++ b/test/parse.test.js @@ -1,6 +1,7 @@ import moment from 'moment' import MockDate from 'mockdate' import dayjs from '../src' +import { REGEX_PARSE } from '../src/constant' beforeEach(() => { MockDate.set(new Date()) @@ -125,3 +126,12 @@ it('Clone with same value', () => { const another = newBase.clone() expect(newBase.toString()).toBe(another.toString()) }) + +describe('REGEX_PARSE', () => { + it('2020/9/30', () => { + const date = '2020/9/30' + const d = date.match(REGEX_PARSE) + expect(dayjs(date).valueOf()).toBe(moment(date).valueOf()) + expect(d.join('-')).toBe('2020/9/30-2020-9-30----') + }) +})