const socketio = new Server();
import Server from 'socket.io';
SyntaxError: The requested module 'socket.io' does not provide an export named 'default'
There are two kinds of exports: named exports (several per module) and default exports (one per module). It is possible to use both at the same time, but usually it is best to keep them separate.
Why are you receiving this error: The import statement you wrote, provides the Server
which is not a default export. If socket.io had actually exported Server as below, then you would not get an error.
module.exports = {
//Other exports
Server as default
}
You could have done this:
import * as io from "socket.io"
import express from 'express';
import { createServer } from 'http';
const app = express();
const server = createServer(app);
const socketio = new io.Server(server);
Edit:
You can import socket.io like this:
import { Server } from 'socket.io';
import express from 'express';
import { createServer } from 'http';
const app = express();
const server = createServer(app);
const socketio = new Server(server);