Convert Figma logo to code with AI

sindresorhus logopretty-ms

Convert milliseconds to a human readable string: `1337000000` → `15d 11h 23m 20s`

1,072
65
1,072
3

Top Related Projects

47,968

Parse, validate, manipulate, and display dates in javascript.

35,025

⏳ Modern JavaScript date utility library ⌛️

46,822

⏰ Day.js 2kB immutable date-time library alternative to Moment.js with the same modern API

5,137

Tiny millisecond conversion utility

A tiny (349B) reusable date formatter. Extremely fast!

Quick Overview

Pretty-ms is a lightweight JavaScript library that converts milliseconds to a human-readable string format. It provides a simple and flexible way to represent time durations in a more readable manner, making it useful for various applications, including logging, user interfaces, and time-based calculations.

Pros

  • Easy to use with a simple API
  • Highly customizable output format
  • Supports both Node.js and browser environments
  • Actively maintained with regular updates

Cons

  • Limited to millisecond-based input
  • May require additional formatting for complex time representations
  • Doesn't support localization out of the box

Code Examples

Converting milliseconds to a human-readable string:

import prettyMilliseconds from 'pretty-ms';

console.log(prettyMilliseconds(1337000000));
//=> '15d 11h 23m 20s'

Using compact option for shorter output:

import prettyMilliseconds from 'pretty-ms';

console.log(prettyMilliseconds(1337, {compact: true}));
//=> '1.3s'

Customizing units and separators:

import prettyMilliseconds from 'pretty-ms';

console.log(prettyMilliseconds(1337, {
    separateMilliseconds: true,
    formatSubMilliseconds: true,
    separatorString: ' | '
}));
//=> '1s | 337ms'

Getting Started

To use pretty-ms in your project, follow these steps:

  1. Install the package using npm:

    npm install pretty-ms
    
  2. Import and use the function in your JavaScript code:

    import prettyMilliseconds from 'pretty-ms';
    
    const duration = prettyMilliseconds(1234567890);
    console.log(duration);
    //=> '14d 6h 56m 7s'
    

That's it! You can now start using pretty-ms to convert milliseconds to human-readable strings in your project.

Competitor Comparisons

47,968

Parse, validate, manipulate, and display dates in javascript.

Pros of moment

  • Comprehensive date and time manipulation library with extensive features
  • Supports parsing, validating, manipulating, and formatting dates
  • Well-established with a large community and extensive documentation

Cons of moment

  • Larger bundle size, which can impact performance in browser environments
  • More complex API due to its extensive feature set
  • No longer recommended for new projects (in maintenance mode)

Code comparison

moment:

const duration = moment.duration(123456789);
console.log(duration.humanize()); // "1 day"
console.log(duration.asHours());  // 34.293552500000005

pretty-ms:

const prettyMs = require('pretty-ms');
console.log(prettyMs(123456789)); // "1d 10h 17m 36s 789ms"
console.log(prettyMs(123456789, {compact: true})); // "1d 10h"

Key differences

  • pretty-ms focuses specifically on converting milliseconds to human-readable strings
  • moment provides a more comprehensive date and time manipulation toolkit
  • pretty-ms is lightweight and has a simpler API for its specific use case
  • moment offers more flexibility in formatting and manipulating dates and times

Use cases

  • Choose pretty-ms for simple millisecond to human-readable string conversion
  • Use moment for complex date and time operations, parsing, and formatting
  • Consider alternatives like date-fns or Luxon for new projects requiring comprehensive date/time functionality
35,025

⏳ Modern JavaScript date utility library ⌛️

Pros of date-fns

  • Comprehensive date manipulation library with a wide range of functions
  • Modular architecture allows for tree-shaking and smaller bundle sizes
  • Supports multiple locales for internationalization

Cons of date-fns

  • Larger package size compared to pretty-ms
  • Steeper learning curve due to its extensive API
  • May be overkill for simple time formatting tasks

Code Comparison

pretty-ms:

import prettyMs from 'pretty-ms';

console.log(prettyMs(1337000000)); // Output: 15d 11h 23m 20s

date-fns:

import { formatDuration, intervalToDuration } from 'date-fns';

const duration = intervalToDuration({ start: 0, end: 1337000000 });
console.log(formatDuration(duration)); // Output: 15 days 11 hours 23 minutes 20 seconds

pretty-ms is a lightweight library focused on converting milliseconds to human-readable strings, while date-fns is a more comprehensive date manipulation library. pretty-ms excels in simplicity and ease of use for basic time formatting tasks, whereas date-fns offers a broader range of date-related functions and more flexibility in formatting options. The choice between the two depends on the specific requirements of your project and the complexity of date operations needed.

46,822

⏰ Day.js 2kB immutable date-time library alternative to Moment.js with the same modern API

Pros of dayjs

  • More comprehensive date and time manipulation library
  • Supports parsing, validating, manipulating, and formatting dates
  • Chainable API for more complex operations

Cons of dayjs

  • Larger bundle size due to more features
  • May be overkill for simple time formatting tasks
  • Steeper learning curve for basic use cases

Code comparison

pretty-ms:

import prettyMs from 'pretty-ms';

console.log(prettyMs(1337000000));
// Output: 15d 11h 23m 20s

dayjs:

import dayjs from 'dayjs';
import duration from 'dayjs/plugin/duration';

dayjs.extend(duration);
console.log(dayjs.duration(1337000000).format('D[d] H[h] m[m] s[s]'));
// Output: 15d 11h 23m 20s

Summary

pretty-ms is a lightweight library focused on converting milliseconds to human-readable strings, while dayjs is a more feature-rich date and time manipulation library. pretty-ms is simpler to use for basic time formatting tasks, but dayjs offers more flexibility for complex date and time operations. The choice between the two depends on the specific requirements of your project and the level of functionality needed.

5,137

Tiny millisecond conversion utility

Pros of ms

  • Smaller package size and simpler implementation
  • Supports both parsing and formatting of time strings
  • Has a longer history and more widespread adoption

Cons of ms

  • Less customization options for output formatting
  • Doesn't support millisecond precision
  • Limited localization support

Code Comparison

ms:

ms('2 days')  // 172800000
ms('1d')      // 86400000
ms(60000)     // '1m'

pretty-ms:

prettyMs(1337000000) // '15d 11h 23m 20s'
prettyMs(1337)       // '1.3s'
prettyMs(133)        // '133ms'

Key Differences

  • ms focuses on simplicity and bidirectional conversion between milliseconds and human-readable strings
  • pretty-ms specializes in formatting milliseconds into more detailed, customizable human-readable strings
  • ms uses shorthand notations (e.g., '2d' for 2 days), while pretty-ms provides more verbose output by default
  • pretty-ms offers options for customizing output format, including unit display and precision

Use Cases

  • Choose ms for simple time string parsing and basic formatting needs
  • Opt for pretty-ms when more detailed and customizable time formatting is required, especially for displaying durations to end-users

A tiny (349B) reusable date formatter. Extremely fast!

Pros of tinydate

  • Extremely lightweight (294 bytes minified + gzipped)
  • Focused on date formatting with a simple, customizable API
  • Faster performance for basic date formatting tasks

Cons of tinydate

  • Limited functionality compared to pretty-ms (only handles date formatting)
  • Doesn't support time duration formatting or parsing
  • No built-in localization support

Code Comparison

tinydate:

import tinydate from 'tinydate';
const stamp = tinydate('{YYYY}-{MM}-{DD}');
console.log(stamp(new Date()));

pretty-ms:

import prettyMs from 'pretty-ms';
console.log(prettyMs(1337000000));
console.log(prettyMs(1337, { verbose: true }));

Summary

tinydate is a minimalist library focused on date formatting, offering a tiny footprint and fast performance. It's ideal for projects that only need basic date formatting functionality.

pretty-ms, on the other hand, is more versatile, specializing in converting milliseconds to human-readable strings. It offers more features like time duration formatting and verbose output options.

Choose tinydate for lightweight date formatting needs, and pretty-ms for more comprehensive time and duration handling requirements.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

pretty-ms

Convert milliseconds to a human readable string: 1337000000 → 15d 11h 23m 20s

Install

npm install pretty-ms

Usage

import prettyMilliseconds from 'pretty-ms';

prettyMilliseconds(1337000000);
//=> '15d 11h 23m 20s'

prettyMilliseconds(1337000000n);
//=> '15d 11h 23m 20s'

prettyMilliseconds(1337);
//=> '1.3s'

prettyMilliseconds(133);
//=> '133ms'

// `compact` option
prettyMilliseconds(1337, {compact: true});
//=> '1s'

// `verbose` option
prettyMilliseconds(1335669000, {verbose: true});
//=> '15 days 11 hours 1 minute 9 seconds'

// `colonNotation` option
prettyMilliseconds(95500, {colonNotation: true});
//=> '1:35.5'

// `formatSubMilliseconds` option
prettyMilliseconds(100.400080, {formatSubMilliseconds: true})
//=> '100ms 400µs 80ns'

// Can be useful for time durations
prettyMilliseconds(new Date(2014, 0, 1, 10, 40) - new Date(2014, 0, 1, 10, 5))
//=> '35m'

API

prettyMilliseconds(milliseconds, options?)

milliseconds

Type: number | bigint

Milliseconds to humanize.

options

Type: object

secondsDecimalDigits

Type: number
Default: 1

Number of digits to appear after the seconds decimal point.

millisecondsDecimalDigits

Type: number
Default: 0

Number of digits to appear after the milliseconds decimal point.

Useful in combination with process.hrtime().

keepDecimalsOnWholeSeconds

Type: boolean
Default: false

Keep milliseconds on whole seconds: 13s → 13.0s.

Useful when you are showing a number of seconds spent on an operation and don't want the width of the output to change when hitting a whole number.

compact

Type: boolean
Default: false

Only show the first unit: 1h 10m → 1h.

Also ensures that millisecondsDecimalDigits and secondsDecimalDigits are both set to 0.

unitCount

Type: number
Default: Infinity

Number of units to show. Setting compact to true overrides this option.

verbose

Type: boolean
Default: false

Use full-length units: 5h 1m 45s → 5 hours 1 minute 45 seconds

separateMilliseconds

Type: boolean
Default: false

Show milliseconds separately. This means they won't be included in the decimal part of the seconds.

formatSubMilliseconds

Type: boolean
Default: false

Show microseconds and nanoseconds.

colonNotation

Type: boolean
Default: false

Display time using colon notation: 5h 1m 45s → 5:01:45. Always shows time in at least minutes: 1s → 0:01

Useful when you want to display time without the time units, similar to a digital watch.

Setting colonNotation to true overrides the following options to false:

  • compact
  • formatSubMilliseconds
  • separateMilliseconds
  • verbose
hideYear

Type: boolean
Default: false

Hides the year and shows the hidden year additionally as days (365 per year): 1y 3d 5h 1m 45s → 368d 5h 1m 45s.

hideYearAndDays

Type: boolean
Default: false

Hides the year and days and shows the hidden values additionally as hours: 1y 3d 5h 1m 45s → 8837h 1m 45s.

hideSeconds

Type: boolean
Default: false

Hides the seconds: 1y 3d 5h 1m 45s → 1y 3d 5h 1m.

Related

NPM DownloadsLast 30 Days