add js to sse example (#281)
This commit is contained in:
@@ -1,16 +1,28 @@
|
||||
import asyncio
|
||||
from microdot import Microdot
|
||||
from microdot import Microdot, send_file
|
||||
from microdot.sse import with_sse
|
||||
|
||||
app = Microdot()
|
||||
|
||||
|
||||
@app.route("/")
|
||||
async def main(request):
|
||||
return send_file('index.html')
|
||||
|
||||
|
||||
@app.route('/events')
|
||||
@with_sse
|
||||
async def events(request, sse):
|
||||
for i in range(10):
|
||||
await asyncio.sleep(1)
|
||||
await sse.send({'counter': i})
|
||||
print('Client connected')
|
||||
try:
|
||||
i = 0
|
||||
while True:
|
||||
await asyncio.sleep(1)
|
||||
i += 1
|
||||
await sse.send({'counter': i})
|
||||
except asyncio.CancelledError:
|
||||
pass
|
||||
print('Client disconnected')
|
||||
|
||||
|
||||
app.run(debug=True)
|
||||
app.run()
|
||||
|
||||
30
examples/sse/index.html
Normal file
30
examples/sse/index.html
Normal file
@@ -0,0 +1,30 @@
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<title>Microdot SSE Example</title>
|
||||
<meta charset="UTF-8">
|
||||
</head>
|
||||
<body>
|
||||
<h1>Microdot SSE Example</h1>
|
||||
<div id="log"></div>
|
||||
<script>
|
||||
const log = (text, color) => {
|
||||
document.getElementById('log').innerHTML += `<span style="color: ${color}">${text}</span><br>`;
|
||||
};
|
||||
|
||||
const eventSource = new EventSource('/events');
|
||||
|
||||
eventSource.onopen = () => {
|
||||
log('Connection to server opened.', 'black');
|
||||
};
|
||||
|
||||
eventSource.onmessage = (event) => {
|
||||
log(`Received message: ${event.data}`, 'blue');
|
||||
};
|
||||
|
||||
eventSource.onerror = (event) => {
|
||||
log(`EventSource failed: ${event.type}`, 'red');
|
||||
};
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
||||
Reference in New Issue
Block a user