Ставим реакт.
npm install react react-dom --save
Ставим express.
npm install express --save
Ставим typescript.
npm install typescript --save
Установим типы для nodejs
npm install @types/node --save
Создаем конфигурацию в tsconfig.json
{
"compilerOptions": {
"module": "commonjs",
"target": "ES5",
"outDir": "dist",
"rootDir": "src"
},
"exclude": [
"node_modules"
]
}
Запуск билдера.
node ./node_modules/typescript/bin/tsc --watch
Установим nodemon
npm install --save nodemon
Настроим его конфигурацию в nodemon.json
{
"verbose": false,
"ignore": ["node_modules"],
"watch": ["src/*"],
"ext": "*"
}
Необходимо отслеживать исходный код в src, а не откомпилированный в dist!
Создадим простой сервер.
var express = require('express');
const app = require('express')();
const server = require('http').createServer(app);
app.use(express.static('.'));
server.listen(5000, () => {
console.log('Listening 5000');
});
Запуск
node_modules/nodemon/bin/nodemon.js dist/server/index.js
Простой шаблон страницы.
<!DOCTYPE html>
<html>
<head><title>TypeScript Greeter</title>
<script src="node_modules/systemjs/dist/system.js"></script>
</head>
<body>
<h1>Hello from Node!</h1>
</body>
</html>
Установим универсальный загрузчик модулей.
npm install systemjs@0.19.22 --save
Создаем файл client/index.ts
console.log('Start!!!')
Добавим скрипт загрузки.
<script>
SystemJS.config({
defaultJSExtensions: true
});
SystemJS.import('dist/client/index.js');
</script>
Ставим либу socket.io.
npm install socket.io @types/socket.io --save
Подключим ее на клиенте и попытаемся создать подключение.
Создаем новый файл в client/includes/SocketConnection.ts
import { Client } from 'socket.io';
import * as io from 'socket.io';
export class SocketConnection {
socket: any;
constructor(url: string) {
this.socket = io(url, {transports:['websocket']});
}
}
this.socket = io(url, {transports:['websocket']})
.on('connect', (connection) => {
this.socket.emit('hello',{message: 'hello message'});
})
Подключаем и используем в client/index.ts
import { SocketConnection } from './includes/SocketConnection';
var socket = new SocketConnection('ws://localhost:5000')
console.log('Start!!!')
Добавляем пути в загрузчик.
<script>
SystemJS.config({
defaultJSExtensions: true,
map: {
'socket.io': 'node_modules/socket.io-client/dist'
},
packages: {
'socket.io': {
main: './socket.io.js'
}
}
});
SystemJS.import('dist/client/index.js');
</script>
ссылка на документацию по клиенту
Добавляем сокет сервер на сервере .
const server = require('http').createServer(app);
// adding socket listener
const io = require('socket.io')(server, {});
Создаем класс сокет соединения на сервере server/includes/SocketServer.ts
export class SocketServer {
constructor(io: any) {
io.on('connection', socket => {
console.log('Connected');
console.log(socket.id);
});
}
}
Создаем объект класса SocketServer в входном файле сервера server/index.ts.
// adding socket listener
const io = require('socket.io')(server, {});
var socketServer = new SocketServer(io);
npm install swig --save
Доработаем входной файл сервера.
app.set('views', __dirname + '/../../src/server/tpl');
app.engine('html', require('swig').renderFile);
app.use("/", function(request, response){
response.render("index.html");
});
Перенесем шаблон index.html в src/server/tpl.
Установим библиотеку.
npm install livereload --save
Добавим следующее в server/index.ts.
// livereload
const livereload = require("livereload");
const liveReloadServer = livereload.createServer();
liveReloadServer.watch(__dirname, '/../../src');
liveReloadServer.server.once("connection", () => {
setTimeout(() => {
liveReloadServer.refresh("/");
}, 1000);
});
const connectLivereload = require("connect-livereload");
app.use(connectLivereload());
app.use(connectLivereload()) - автоматически добавит тег скрипта на все страницы.
** Необходимо следить за позицией кода и размещать перед подключение шаблонизатора **
Иногда сервер livereload не завершается и оставляет открытым порт 35729.
Поэтому перед стартом сервера можно принудительно прибивать процесс на порту 35729.
kill -9 $(lsof -t -i:35729)
(ссылка на библиотеку)https://www.npmjs.com/package/concurrently
npm install concurrently --save
Запустим 2 команды, пропишем команду start в package.json
“scripts”: { … “start”: “concurrently "./bin/run.cmd" "./bin/build.cmd"” },