discord.js

A powerful JavaScript library for interacting with the Discord API

README


discord.js


Discord server npm version npm downloads Tests status Code coverage

Vercel


About


discord.js is a powerful Node.js module that allows you to easily interact with the

- Object-oriented
- Predictable abstractions
- Performant
- 100% coverage of the Discord API

Installation


Node.js 16.9.0 or newer is required.

  1. ```sh-session
  2. npm install discord.js
  3. yarn add discord.js
  4. pnpm add discord.js
  5. ```

Optional packages


- zlib-sync for WebSocket data compression and inflation (npm install zlib-sync)
- erlpack for significantly faster WebSocket data (de)serialisation (npm install discord/erlpack)
- bufferutil for a much faster WebSocket connection (npm install bufferutil)
- utf-8-validate in combination withbufferutil for much faster WebSocket processing (npm install utf-8-validate)
- @discordjs/voice for interacting with the Discord Voice API (npm install @discordjs/voice)

Example usage


Install discord.js:

  1. ```sh-session
  2. npm install discord.js
  3. yarn add discord.js
  4. pnpm add discord.js
  5. ```

Register a slash command against the Discord API:

  1. ``` js
  2. const { REST, Routes } = require('discord.js');

  3. const commands = [
  4. {
  5.   name: 'ping',
  6.   description: 'Replies with Pong!',
  7. },
  8. ];

  9. const rest = new REST({ version: '10' }).setToken(TOKEN);

  10. (async () => {
  11. try {
  12.   console.log('Started refreshing application (/) commands.');

  13.   await rest.put(Routes.applicationCommands(CLIENT_ID), { body: commands });

  14.   console.log('Successfully reloaded application (/) commands.');
  15. } catch (error) {
  16.   console.error(error);
  17. }
  18. })();
  19. ```

Afterwards we can create a quite simple example bot:

  1. ``` js
  2. const { Client, GatewayIntentBits } = require('discord.js');
  3. const client = new Client({ intents: [GatewayIntentBits.Guilds] });

  4. client.on('ready', () => {
  5. console.log(`Logged in as ${client.user.tag}!`);
  6. });

  7. client.on('interactionCreate', async (interaction) => {
  8. if (!interaction.isChatInputCommand()) return;

  9. if (interaction.commandName === 'ping') {
  10.   await interaction.reply('Pong!');
  11. }
  12. });

  13. client.login(TOKEN);
  14. ```

Links


- [Website][website] ([source][website-source])
- [Documentation][documentation]
- [Guide][guide] ([source][guide-source])
  See also the [Update Guide][guide-update], including updated and removed items in the library.
- [discord.js Discord server][discord]
- [Discord API Discord server][discord-api]
- [GitHub][source]
- [npm][npm]
- [Related libraries][related-libs]

Extensions


- [RPC][rpc] ([source][rpc-source])

Contributing


Before creating an issue, please ensure that it hasn't already been reported/suggested, and double-check the
[documentation][documentation].  
See [the contribution guide][contributing] if you'd like to submit a PR.

Help


If you don't understand something in the documentation, you are experiencing problems, or you just need a gentle
nudge in the right direction, please don't hesitate to join our official [discord.js Server][discord].

[website]: https://discord.js.org/
[website-source]: https://github.com/discordjs/discord.js/tree/main/apps/website
[documentation]: https://discord.js.org/#/docs
[guide]: https://discordjs.guide/
[guide-source]: https://github.com/discordjs/guide
[guide-update]: https://discordjs.guide/additional-info/changes-in-v14.html
[discord]: https://discord.gg/djs
[discord-api]: https://discord.gg/discord-api
[source]: https://github.com/discordjs/discord.js/tree/main/packages/discord.js
[npm]: https://www.npmjs.com/package/discord.js
[related-libs]: https://discord.com/developers/docs/topics/community-resources#libraries
[rpc]: https://www.npmjs.com/package/discord-rpc
[rpc-source]: https://github.com/discordjs/RPC
[contributing]: https://github.com/discordjs/discord.js/blob/main/.github/CONTRIBUTING.md