Сначала мы пишем слушатель в php-файле.
затем он пишет процесс javascript, который заставит слушателя коснуться и получить обратную связь.
Я отправляю сообщение сокета e 'getOpenPopUp', к которому мы подключены с помощью JavaScript. Сокет на стороне php отправляет сообщение openPopUp
всем клиентам после его проверки. это сообщение получено на стороне javascript. Откроется всплывающее окно. мой английский не очень хорош Извините, я не мог сказать.
socket.php
- Ratchet Class
Храповик
<?php
require __DIR__.'/vendor/autoload.php';
use Ratchet\MessageComponentInterface;
use Ratchet\ConnectionInterface;
use Ratchet\Server\IoServer;
use Ratchet\Http\HttpServer;
use Ratchet\WebSocket\WsServer;
class Application implements MessageComponentInterface {
protected $clients;
public function __construct() {
$this->clients = new \SplObjectStorage;
}
public function onOpen(ConnectionInterface $conn) {
$this->clients->attach($conn);
}
public function onMessage(ConnectionInterface $from, $msg) {
if ( $msg === 'getOpenPopUp' ) {
foreach ($this->clients as $client) {
$client->send('openPopUp');
}
}
}
public function onClose(ConnectionInterface $conn) {
}
public function onError(ConnectionInterface $conn, \Exception $e) {
}
}
$server = IoServer::factory(
new HttpServer(
new WsServer(
new Application()
)
),
8080
);
$server->run();
App.js
- WebSocket
MDN Написание клиентских приложений WebSocket
var socket = new WebSocket('ws://localhost:8080');
var button = document.getElementById('button');
button.addEventListener('click', function() {
console.log('click')
socket.send('getOpenPopUp');
});
socket.onmessage = function(e) {
console.log(e)
if ( e.data === 'openPopUp' ) {
UIkit.modal.confirm('UIkit confirm!');
}
}