Мне нужно получать котировки валют в режиме реального времени, без перезагрузки страницы и нажатия кнопок.
Чтобы решить эту проблему, нам пришлось прибегнуть к следующим технологиям: узел js, websocket.io, Redis, API донора данных.
В консоли я получаю следующие данные:
{"symbol": "EURUSD", "bid": 1.13624, "ask": 1.13624, "price": 1.13624}
на самом деле все работает, и это то, что мне нужно.Но я не могу понять, как передать те же данные в браузер, чтобы это было так:
EURUSD | bid - 1.13624 | ask - 1.13624 | price - 1.13624
Вот код js:
const redis = require('redis');
const settings = {
REDIS: {
HOST: 'localhost'
}
}
let redisClient = new redis.createClient(settings.REDIS);
var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);
app.get('/', function(req, res){
res.sendFile(__dirname + '/index.html');
});
http.listen(3000, function(){
console.log('listening on *:3000');
});
function getQuote(symbol, callback) {
redisClient.get(symbol, (error, quote) => {
if (error) {
throw new Error(error);
}
quote = JSON.parse(quote);
callback(quote);
});
}
setInterval(() => {
getQuote('EURUSD', (q) => {
const formattedQ = `${q.SYMBOL} | bid - ${q.bid} | ask - ${q.ask} | price - ${q.price}`;
console.log(formattedQ);
});
}, 10);
io.on('connection', function(socket){
socket.on('get_quote', function(msg){
io.emit('get_quote', getQuote('EURUSD', (q) => /* ??? what to insert here? -> (formattedQ) ??? */));
});
});
ИHTML-файл:
<script src="/socket.io/socket.io.js"></script>
<script src="https://code.jquery.com/jquery-1.11.1.js"></script>
<script>
$(function () {
var socket = io();
socket.on('get_quote', function(msg){
// ??? what to insert here to update quotes without rebooting ???
});
});
</script>