Heim  >  Artikel  >  Web-Frontend  >  Verwendung von Fecha für die JS-Datenverarbeitung

Verwendung von Fecha für die JS-Datenverarbeitung

高洛峰
高洛峰Original
2016-12-06 11:12:451593Durchsuche

Vorwort

Derzeit verwenden wir Fecha für die Datenverarbeitung im Projekt und haben Fecha neu verpackt, um den tatsächlichen Anforderungen des Projekts gerecht zu werden.

Fecha-Einführung

fecha ist eine JS-Bibliothek für die Datumsformatierung und -analyse. Sie bietet leistungsstarke Datumsverarbeitungsfunktionen, ist leistungsstark und nur 2 KB groß. Die Installationsmethode ist einfach, einfach npm install fecha --save

Formatierung (Datumsformatierung)

fecha bietet eine Formatierungsmethode. fecha.format nimmt ein Date-Objekt (oder einen Zeitstempel) und ein Datumsformat als String und gibt einen String (das verarbeitete Datum) zurück.

Hinweis: Wenn die eingehenden Parameter ungültig sind, meldet fecha einen Fehler

fecha.format(<Date Object>, <String Format>);
 
// 自定义格式化
// string format可以传入自定义的格式,fecha会返回相应的格式
fecha.format(new Date(2015, 10, 20), &#39;dddd MMMM Do, YYYY&#39;); // &#39;Friday November 20th, 2015&#39;
fecha.format(new Date(1998, 5, 3, 15, 23, 10, 350), &#39;YYYY-MM-DD hh:mm:ss.SSS A&#39;);// &#39;1998-06-03 03:23:10.350 PM&#39;
 
// 通过自定义的常量来设置日期格式
fecha.format(new Date(2015, 10, 20), &#39;mediumDate&#39;);// &#39;Nov 20, 2015&#39;
fecha.format(new Date(2015, 2, 10, 5, 30, 20), &#39;shortTime&#39;);// &#39;05:30&#39;
 
// 添加一些其他常量
fecha.format(new Date(2001, 2, 5, 6, 7, 2, 5), &#39;[on] MM-DD-YYYY [at] HH:mm&#39;); // &#39;on 03-05-2001 at 06:07&#39;

Auf diese Weise können wir problemlos mit neuen Datumsangaben umgehen ( ) → Es besteht eine solche Nachfrage am 19. November 2016

fecha.format(new Date(), &#39;YYYY[年]MM[月]DD[日]&#39;)

Parsing (Datumsanalyse)

fecha zusätzlich A Parse-Methode wird bereitgestellt. Ähnlich wie beim Format empfängt fecha.parse eine Datumszeichenfolge und ein Datumsformat in Zeichenfolgenform und gibt dann ein Datumsobjekt zurück.

Hinweis: Wenn die übergebenen Parameter ungültig sind, meldet fecha einen Fehler

// 自定义格式化
formatsfecha.parse(&#39;February 3rd, 2014&#39;, &#39;MMMM Do, YYYY&#39;); // new Date(2014, 1, 3)
fecha.parse(&#39;10-12-10 14:11:12&#39;, &#39;YY-MM-DD HH:mm:ss&#39;); // new Date(2010, 11, 10, 14, 11, 12)
 
// 通过自定义的常量来设置日期格式
 
fecha.parse(&#39;5/3/98&#39;, &#39;shortDate&#39;); // new Date(1998, 4, 3)
fecha.parse(&#39;November 4, 2005&#39;, &#39;longDate&#39;); // new Date(2005, 10, 4)

Benutzerdefinierte benannte Konstanten

fecha.masks = {
 &#39;default&#39;: &#39;ddd MMM DD YYYY&#39;,
 shortDate: &#39;M/D/YY&#39;,
 mediumDate: &#39;MMM D, YYYY&#39;,
 longDate: &#39;MMMM D, YYYY&#39;,
 fullDate: &#39;dddd, MMMM D, YYYY&#39;,
 shortTime: &#39;HH:mm&#39;,
 mediumTime: &#39;HH:mm:ss&#39;,
 longTime: &#39;HH:mm:ss.SSS&#39;
};

Internationale Unterstützung (Erweiterung)

Im tatsächlichen Gebrauch werden wir auf sehr lokalisierte Anforderungen stoßen, wie z. B. die Einstellung „Montag“. Seltsame Anforderungen wie z B. „Dienstag“ und „Montag“, oder Montag muss auf „Montag“ eingestellt werden, Dienstag muss auf „Feuersonntag“ usw. eingestellt werden.

Wir alle können diese Anforderungen durch Analyse und Formatierung erfüllen Dies wird mit der in erwähnten i18n-Unterstützung erreicht.

Ändern Sie einfach die entsprechenden Einstellungen in fecha.i18n.

fecha.i18n = {
 dayNamesShort: [&#39;周日&#39;, &#39;周一&#39;, &#39;周二&#39;, &#39;周三&#39;, &#39;周四&#39;, &#39;周五&#39;, &#39;周六&#39;],
 dayNames: [&#39;星期日&#39;, &#39;星期一&#39;, &#39;星期二&#39;, &#39;星期三&#39;, &#39;星期四&#39;, &#39;星期五&#39;, &#39;星期六&#39;],
 monthNamesShort: [&#39;01&#39;, &#39;02&#39;, &#39;03&#39;, &#39;04&#39;, &#39;05&#39;, &#39;06&#39;, &#39;07&#39;, &#39;08&#39;, &#39;09&#39;, &#39;10&#39;, &#39;11&#39;, &#39;12&#39;],
 monthNames: [&#39;一月&#39;, &#39;二月&#39;, &#39;三月&#39;, &#39;四月&#39;, &#39;五月&#39;, &#39;六月&#39;, &#39;七月&#39;, &#39;八月&#39;, &#39;九月&#39;, &#39;十月&#39;, &#39;十一月&#39;, &#39;十二月&#39;],
 amPm: [&#39;上午&#39;, &#39;下午&#39;],
 // D is the day of the month, function returns something like... 3rd or 11th
 DoFn: function (D) {
  return D + [ &#39;th&#39;, &#39;st&#39;, &#39;nd&#39;, &#39;rd&#39; ][ D % 10 > 3 ? 0 : (D - D % 10 !== 10) * D % 10 ];
 }
}

Token formatieren

Verwendung von Fecha für die JS-Datenverarbeitung

Neukapselung von Fecha

Bei tatsächlichen Bedürfnissen werden wir auch auf verschiedene chaotische Bedürfnisse stoßen

2016-11-20 → 明天 11-20
2016-11-23 → 下周三 11-23
10:00 加上100分钟的时间
...

Fecha bietet zwar einige sehr praktische Methoden zur Datenverarbeitung, aber unter allen möglichen seltsamen Umständen Bedürfnisse müssen wir Fecha immer noch neu kapseln, um den tatsächlichen Bedürfnissen gerecht zu werden. Darüber hinaus werden durch die Kapselung von Fecha und deren Extraktion in öffentliche Komponenten auch mehrere i18n-Konfigurationen und Maskeneinstellungen auf mehreren Seiten vermieden. Außerdem ist es bequemer, die Seite aufzurufen.

Ein Beispiel für eine gekapselte öffentliche Fecha-Komponente

import fecha from 'fecha'
 
fecha.i18n = {
 dayNamesShort: [&#39;周日&#39;, &#39;周一&#39;, &#39;周二&#39;, &#39;周三&#39;, &#39;周四&#39;, &#39;周五&#39;, &#39;周六&#39;],
 dayNames: [&#39;星期日&#39;, &#39;星期一&#39;, &#39;星期二&#39;, &#39;星期三&#39;, &#39;星期四&#39;, &#39;星期五&#39;, &#39;星期六&#39;],
 monthNamesShort: [&#39;01&#39;, &#39;02&#39;, &#39;03&#39;, &#39;04&#39;, &#39;05&#39;, &#39;06&#39;, &#39;07&#39;, &#39;08&#39;, &#39;09&#39;, &#39;10&#39;, &#39;11&#39;, &#39;12&#39;],
 monthNames: [&#39;一月&#39;, &#39;二月&#39;, &#39;三月&#39;, &#39;四月&#39;, &#39;五月&#39;, &#39;六月&#39;, &#39;七月&#39;, &#39;八月&#39;, &#39;九月&#39;, &#39;十月&#39;, &#39;十一月&#39;, &#39;十二月&#39;],
 amPm: [&#39;上午&#39;, &#39;下午&#39;],
 // D is the day of the month, function returns something like... 3rd or 11th
 DoFn: function (D) {
  return D + [ &#39;th&#39;, &#39;st&#39;, &#39;nd&#39;, &#39;rd&#39; ][ D % 10 > 3 ? 0 : (D - D % 10 !== 10) * D % 10 ];
 }
}
 
fecha.masks = {
 &#39;default&#39;: &#39;ddd MMM DD YYYY&#39;,
 shortDate: &#39;M/D/YY&#39;,
 mediumDate: &#39;MMM D, YYYY&#39;,
 longDate: &#39;MMMM D, YYYY&#39;,
 fullDate: &#39;dddd, MMMM D, YYYY&#39;,
 shortTime: &#39;HH:mm&#39;,
 mediumTime: &#39;HH:mm:ss&#39;,
 longTime: &#39;HH:mm:ss.SSS&#39;
};
// str 必须是 YYYYMMDD格式
// YYYYMMDD → xx(今天/后天/下周一...)MM月DD日
fecha.getDateString = (str, format) => {
 let now = Date.now();
 let today = fecha.format.bind(null, new Date());
 let tomorrow = fecha.format.bind(null, new Date(now + 86400 * 1000));
 let dayafter = fecha.format.bind(null, new Date(now + 86400 * 2 * 1000));
 
 let week_start = parseInt(today('d'));
 
 let result = {};
 // 从本周一到下周日共14个
 let weeks = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13];
 result[today(YYYYMMDD)] = `今天 ${today('MM')}月${today('DD')}日`;
 result[tomorrow(YYYYMMDD)] = `明天 ${tomorrow('MM')}月${tomorrow('DD')}日`;
 result[dayafter(YYYYMMDD)] = `后天 ${dayafter('MM')}月${dayafter('DD')}日`;
 
 weeks.slice(week_start + 3).forEach((after) => {
  let step = after - week_start;
  let _dayafter = fecha.format.bind(null, new Date(now + 86400 * step * 1000));
  result[_dayafter(YYYYMMDD)] = `${(after < 8 ? '本' : '下')}${_dayafter('ddd')} ${_dayafter('MM')}-${_dayafter('DD')}`;
 })
 // 如果出现下下周一的情况则输出调用时传入的格式规范
 return result || format(fecha.parse(str, YYYYMMDD), format)
}
 
export default fecha

Wenn andere Seiten die Datumsverarbeitung verwenden müssen, müssen Sie nur Fecha aufrufen auf der Seite Komponenten reichen aus.

import DateParser from &#39;fecha&#39;
 
...
 let date = DateParser.getDateString(&#39;20161123&#39;, &#39;YYYY-MM-DD&#39;)
...

Wenn die vorhandene Datumsverarbeitung den tatsächlichen Bedarf nicht lösen kann, müssen Sie die Methode nur selbst in der Fecha-Komponente hinzufügen. Nach dem Schreiben der Kommentare können Kollegen diese direkt anrufen, wenn sie dieselbe Funktion entwickeln, was die Effizienz des Teams verbessert.


Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn