progress.html 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>Chat</title>
  5. </head>
  6. <style>
  7. #myProgress {
  8. width: 100%;
  9. background-color: #ddd;
  10. }
  11. #myBar {
  12. width: 10%;
  13. height: 30px;
  14. background-color: #04AA6D;
  15. text-align: center;
  16. line-height: 30px;
  17. color: white;
  18. }
  19. </style>
  20. <body>
  21. <h1>WebSocket Chat</h1>
  22. <h2>Your ID: <span id="ws-id"></span></h2>
  23. <form action="" onsubmit="sendMessage(event)">
  24. <input type="text" id="messageText" autocomplete="off"/>
  25. <button>Send</button>
  26. </form>
  27. <ul id='messages'>
  28. </ul>
  29. <script>
  30. var client_id = Date.now()
  31. document.querySelector("#ws-id").textContent = client_id;
  32. var ws = new WebSocket(`ws://www.choozmo.com:8888/ws/${client_id}`);
  33. ws.onmessage = function(event) {
  34. var messages = document.getElementById('messages')
  35. var message = document.createElement('li')
  36. var content = document.createTextNode(event.data)
  37. message.appendChild(content)
  38. messages.appendChild(message)
  39. var elem = document.getElementById("myBar");
  40. elem.style.width = message + "%";
  41. elem.innerHTML = message + "%";
  42. };
  43. function sendMessage(event) {
  44. var input = document.getElementById("messageText")
  45. ws.send(input.value)
  46. input.value = ''
  47. event.preventDefault()
  48. }
  49. </script>
  50. <div id="myProgress">
  51. <div id="myBar">10%</div>
  52. </div>
  53. <br>
  54. <button onclick="move()">Click Me</button>
  55. <script>
  56. var i = 0;
  57. function move() {
  58. if (i == 0) {
  59. i = 1;
  60. var elem = document.getElementById("myBar");
  61. var width = 10;
  62. var id = setInterval(frame, 10);
  63. function frame() {
  64. if (width >= 100) {
  65. clearInterval(id);
  66. i = 0;
  67. } else {
  68. width++;
  69. elem.style.width = width + "%";
  70. elem.innerHTML = width + "%";
  71. }
  72. }
  73. }
  74. }
  75. </script>
  76. </body>
  77. </html>