Section titled Creating the main fileCreating the main file

This page assumes you've already prepared the configuration files from the previous page. We're using the config.json approach, however feel free to substitute your own!

Tip

Open your code editor and create a new file. We suggest that you save the file as index.js, but you may name it whatever you wish.

Here's the base code to get you started:


_15
// Require the necessary discord.js classes
_15
import { Client, Events, GatewayIntentBits } from 'discord.js';
_15
import config from './config.json' assert { type: 'json' };
_15
_15
// Create a new client instance
_15
const client = new Client({ intents: [GatewayIntentBits.Guilds] });
_15
_15
// When the client is ready, run this code (only once)
_15
// We use 'c' for the event parameter to keep it separate from the already defined 'client'
_15
client.once(Events.ClientReady, (c) => {
_15
console.log(`Ready! Logged in as ${c.user.username}`);
_15
});
_15
_15
// Log in to Discord with your client's token
_15
client.login(config.token);

This is how you create a client instance for your Discord bot and log in to Discord. The GatewayIntentBits.Guilds intents option is necessary for the discord.js client to work as you expect it to, as it ensures that the caches for guilds, channels, and roles are populated and available for internal use.

The term "guild" is used by the Discord API and in discord.js to refer to a Discord server.

Tip

Intents also define which events Discord should send to your bot, and you may wish to enable more than just the minimum. You can read more about the other intents on the Intents topic.

Section titled Running your applicationRunning your application

Open your terminal and run node index.js to start the process. If you see "Ready!" after a few seconds, you're good to go! The next step is to start adding slash commands to develop your bot's functionality.

You can open your package.json file and edit the "main": "index.js" field to point to your main file. You can then run node . in your terminal to start the process!

After closing the process with Ctrl + C, you can press the up arrow on your keyboard to bring up the latest commands you've run. Pressing up and then enter after closing the process is a quick way to start it up again.

Tip

Section titled Resulting codeResulting code