【Javascript】Stream API を使って PHP から現在時刻を表示するサンプル
JavaScriptのStreams APIとPHPを使って、1秒ごとに時刻を更新する方法を説明します。
サーバー側で1秒ごとに時刻を生成し、ブラウザ側でその時刻をリアルタイムで表示する方法を紹介します。
これを使うことでサーバー側の処理状況などHTML側でリアルタイムに受け取って進行状況などを表示することができるかと思います。
サンプルコード
PHPとHTMLのサンプルコードです。
PHP
PHPの処理です。
無限ループを実行し、1秒ごとに現在の時刻を送信します。
1
2
3
4
5
6
7
8
9
10
11
12
| <?php
// 実行時間の無制限
set_time_limit(0);
// 出力バッファクリア
ob_start();
while (true) {
// 時刻表示
echo date('Y/m/d H:i:s') . '\n';
ob_flush();
flush();
sleep(1);
}
|
HTML
HTML側の処理です。
Javascriptも一緒に入っております。
1秒毎に更新されるデータを受け取って画面に表示されるようにしております。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
| <!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>時刻表示</title>
</head>
<body>
<div id="time">時刻を取得中...</div>
<script>
async function fetchTimeStream() {
const response = await fetch('time_stream.php');
const reader = response.body.getReader();
const decoder = new TextDecoder('utf-8');
let buffer = '';
while (true) {
const { value, done } = await reader.read();
if (done) break;
// ストリームを受け取る
buffer += decoder.decode(value, { stream: true });
const lines = buffer.split('\n');
if (lines.length > 1) {
const time = lines.shift();
buffer = lines.join('\n');
document.getElementById('time').innerText = `現在の時刻: ${time}`;
}
}
}
fetchTimeStream();
</script>
</body>
</html>
|
参考