Popular Topics
Formatters
discord.js provides the formatters package which contains a variety of utilities you can use when writing your Discord bot.
Basic Markdown
These functions format strings into all the different Markdown styles supported by Discord.
const { blockQuote, bold, italic, quote, spoiler, strikethrough, underline, subtext } = require('discord.js');
const string = 'Hello!';
const boldString = bold(string);
const italicString = italic(string);
const strikethroughString = strikethrough(string);
const underlineString = underline(string);
const spoilerString = spoiler(string);
const quoteString = quote(string);
const blockquoteString = blockQuote(string);
const subtextString = subtext(string);Links
There are also two functions to format hyperlinks. hyperlink() will format the URL into a masked markdown link, and hideLinkEmbed() will wrap the URL in <>, preventing it from embedding.
const { hyperlink, hideLinkEmbed } = require('discord.js');
const url = 'https://discord.js.org/';
const link = hyperlink('discord.js', url);
const hiddenEmbed = hideLinkEmbed(url);Code blocks
You can use inlineCode() and codeBlock() to turn a string into an inline code block or a regular code block with or without syntax highlighting.
const { inlineCode, codeBlock } = require('discord.js');
const jsString = 'const value = true;';
const inline = inlineCode(jsString);
const codeblock = codeBlock(jsString);
const highlighted = codeBlock('js', jsString);Timestamps
With time(), you can format Unix timestamps and dates into a Discord time string.
const { time, TimestampStyles } = require('discord.js');
const date = new Date();
const timeString = time(date);
const relative = time(date, TimestampStyles.RelativeTime);Mentions
userMention(), channelMention(), and roleMention() all exist to format Snowflakes into mentions.
const { channelMention, roleMention, userMention } = require('discord.js');
const id = '123456789012345678';
const channel = channelMention(id);
const role = roleMention(id);
const user = userMention(id);