Hello World

Javascript Date Format Example 본문

Javascript/Core

Javascript Date Format Example

EnterKey 2016. 1. 12. 10:24
반응형

Date objects

Date objects are based on the number of milliseconds since January 1,1970 UTC. They have no syntax, but are stated using constructors, like below:

1new Date();
2new Date(value);
3new Date(dateString);
4new Date(year, month[, day[, hour[, minute[, second[, millisecond]]]]]);

You can use them like this:

1var today = new Date();
2var birthday = new Date('November 16, 1994 01:00:00');
3var birthday = new Date('1994-11-16T01:00:00');
4var birthday = new Date(1994, 11, 16);
5var birthday = new Date(1994, 11, 16, 1, 0, 0);

Be careful when invoking the Date object, because if you use it without the new operator, it will only return the current date and time as a string.

The Date object has a number of specific qualities to it’s name, for example, if you give it an illogical value, say 3/14/2013, it transforms it into 3/2/2014. If you don’t provide a time and date, the constructor will fill it in with the systems time and date, and if two arguments are supplied, the other ones will be set to 0. JavaScript supports a number of universal formats, and even local equivalents of it, which provides consistency and uniform behavior across platforms.

Date.prototype
Date.prototype allows you to add properties to the Date object. It is used together with the methods, which are divided into getterssetters and conversion getters, but we’ll discus them shortly. The properties inherited from the function are:aritycallerconstructorlength and name.

Methods

The three methods used with the Date object are Date.now(),Date.parse() and Date.UTC().

  • Date.now() returns the current time of the system.
  • Date.parse() parses a string representation of a date and returns the numeric value corresponding it.
  • Date.UTC() returns the number of milliseconds since January 1,1970.

Also there are these methods inherited from the function: applycalltoSource and toString.

Date instances

The methods that Date instances inherit from Date.prototype can be divided into three big groups:GettersSetters andConversion getters.

    • Getters

We use Getters as Date.prototype.getDay, where you can put DateMonthYearMilliseconds and other ones which you can find here, instead of Day.

    • Setters

We use Setters in a similar way: Date.prototype.setMonth. You can find the list on what exactly you can set, here.

    • Conversion getters

And finally, we use Conversion getters to get and convert dates at the same time. It is used like this:Date.prototype.toISOString(), and you can find a whole list on what you can convert here.

Calculating elapsed time

By using Date objects you can calculate how much time has passed since you last did something, like this:

1var start = Date.now();
2 
3randomfunction();
4var end = Date.now();
5var elapsed = end - start;

You get the time in a specific moment, then do something for some time, and then get the time after you finish. You get the difference and that is the elapsed time in milliseconds.

JavaScript Libraries

There are lots of JavaScript libraries dedicated to data formatting. Two of the most efficient are Datejs and Moment.js, both open source and released under the MIT license. We’ll see how they work.

Datejs
You can download Datejs here, and then script it in you main file. It gives you the possibility to format you dates according to where you live, giving you more than 150 options. To do that you just swap the date.js file for a culture specific one, like below:

1<!--Swap this file for the one you need, example for german and french below-->
2<script type="text/javascript" src="date.js"></script>
3 
4<!-- German-->
5<script type="text/javascript" src="date-de-DE.js"></script>
6 
7<!-- French -->
8<script type="text/javascript" src="date-fr-FR.js"></script>

Let’s get our hands on it. Want to know what’s the date today? Write this code:

1Date.today();

Or what will be the day ten days from now?

1Date.today().add(10).days();

If you wanna know what the date will be this Friday, you write this:

1Date.friday();

You can even ask if Friday is today, doing this:

1Date.today().is().friday();

And in case it returns false (it can even return true), you can ask what day it is like so:

1Date.today().getDayName();

You can even get the first Monday or last Sunday of the year by writing this:

1Date.january().first().monday();
2 
3Date.dec().final().sunday();

Included with the Date.js library is a really good replacement for JavaScript Date parse. Take a look at the code:

1Date.parse('today');
2 
3Date.parse('tomorrow');
4 
5Date.parse('July 8');
6 
7Date.parse('July 8th, 2007');
8 
9Date.parse('July 8th, 2007, 10:30 PM');

We have parsed the date of today, tomorrow, July 8th, July 8th of 2007 and July 8th of 2007 at 10:30 PM, just by using theDate.parse(); function.

Moment.js

Moment.js is created to parse, validate, manipulate and display dates in JavaScript. It is designed to work both in the browser and Node.js. You can install it through Bower, npm or NuGet.You can format dates like this:

1moment().format('MMMM Do YYYY, h:mm:ss a'); // December 7th 2014, 6:17:51 pm
2moment().format('dddd');                    // Sunday
3moment().format("MMM Do YY");               // Dec 7th 14
4moment().format('YYYY [escaped] YYYY');     // 2014 escaped 2014                    
5moment().format();                          // 2014-12-07T18:18:11+01:00

You can get a relative time, like this:

1moment("20111031""YYYYMMDD").fromNow(); // 3 years ago
2moment("20120620""YYYYMMDD").fromNow(); // 2 years ago
3moment().startOf('day').fromNow();        // 18 hours ago
4moment().endOf('day').fromNow();          // in 6 hours
5moment().startOf('hour').fromNow();      //20 minutes ago

And it even provides you multiple locale support:

1moment().format('L');    // 07/12/2014
2moment().format('l');    // 7/12/2014
3moment().format('LL');   // 7 Dhjetor 2014
4moment().format('ll');   // 7 Dhj 2014
5moment().format('LLL');  // 7 Dhjetor 2014 18:21
6moment().format('lll');  // 7 Dhj 2014 18:21
7moment().format('LLLL'); // E Diel, 7 Dhjetor 2014 18:21
8moment().format('llll'); // Die, 7 Dhj 2014 18:22

Later.js
Later.js is a library that triggers recurring events, and defines complex schedules. It can even use user-friendly expressions such as “every 10 seconds”. You can install it through npm:

1$ npm install later

Or even using Bower:

1$ bower install later

You can define a schedule by text, recursion or manually like below:

1var textSched = later.parse.text('at 10:15am every weekday');
2var recurSched = later.parse.recur().last().dayOfMonth();
3var manualSched = {schedules: [{M: 3, D: 21}]};

Still you can define more complex schedules like this one, who fires the weekday closest to the 15th of every month except March. Here’s the code:

1var complexSched = later.parse.recur()
2                  .on(15).dayOfMonth().onWeekday().on(2).hour()
3                .and()
4                  .on(14).dayOfMonth().on(6).dayOfWeek().on(2).hour()
5                .and()
6                  .on(16).dayOfMonth().on(2).dayOfWeek().on(2).hour()
7                .except()
8                  .on(3).month();

You can even configure your timezone, either in UTC format or in local time. You configure it in UTC like this:

1later.date.UTC();

And you can turn it to local time like this:

1later.date.localTime();

With Library.js you can even calculate future or past occurrences once you set a recurring schedule. Look at the code snippet below:

1var recurSched = later.parse.recur().last().dayOfMonth();
2      next = later.schedule(recurSched).next(10);

Also a lot of other functions of this library are available, and you can take a look at it’s documentation on Github or even modify it yourself as it’s open-source.

Download the source code

This was an example of JavaScript date format.

Download
You can download the full source code of this example here : DateFormat

출처: http://www.webcodegeeks.com/javascript/javascript-date-format-example

반응형

'Javascript > Core' 카테고리의 다른 글

HTML5 LocalStorage 살펴보기  (0) 2016.02.18
[펌] eval() 함수에 대한 재정의 : eval() is not evil?/  (0) 2016.02.02
4 JavaScript Design Patterns You Should Know  (0) 2016.01.10
DOM  (0) 2016.01.10
Airbnb Javascript Coding Convention  (0) 2016.01.10
Comments