SSE与WebSocket与MQTT

SSE

复制代码
<template>
  <div>
    <h1>实时消息</h1>
    <ul>
      <li v-for="(msg, index) in messages" :key="index">{{ msg }}</li>
    </ul>
  </div>
</template>

<script setup>
import { ref, onMounted, onUnmounted } from 'vue';

const messages = ref([]);  // 存储接收到的消息
let eventSource;

onMounted(() => {
  // 创建 SSE 连接
  eventSource = new EventSource('https://example.com/sse-endpoint');

  // 监听消息事件
  eventSource.onmessage = (event) => {
    messages.value.push(event.data);  // 将新消息推入列表
  };

  // 监听错误事件
  eventSource.onerror = (error) => {
    console.error('SSE 连接错误:', error);
    eventSource.close();  // 出现错误时可以选择关闭连接
  };
});

onUnmounted(() => {
  // 组件卸载时关闭 SSE 连接
  if (eventSource) {
    eventSource.close();
  }
});
</script>

WebSocket

复制代码
<template>
  <div>
    <h1>实时聊天</h1>
    <input v-model="newMessage" @keydown.enter="sendMessage" placeholder="输入消息" />
    <ul>
      <li v-for="(msg, index) in messages" :key="index">{{ msg }}</li>
    </ul>
  </div>
</template>

<script setup>
import { ref, onMounted, onUnmounted } from 'vue';

const messages = ref([]);    // 存储接收到的消息
const newMessage = ref('');   // 存储输入框的消息内容
let socket;

onMounted(() => {
  // 创建 WebSocket 连接
  socket = new WebSocket('wss://example.com/socket-endpoint');

  // 监听消息事件
  socket.onmessage = (event) => {
    messages.value.push(event.data);  // 将接收到的消息添加到列表中
  };

  // 监听错误事件
  socket.onerror = (error) => {
    console.error('WebSocket 错误:', error);
  };

  // 监听 WebSocket 连接关闭
  socket.onclose = () => {
    console.log('WebSocket 连接已关闭');
  };
});

onUnmounted(() => {
  // 组件卸载时关闭 WebSocket 连接
  if (socket) {
    socket.close();
  }
});

// 发送消息
const sendMessage = () => {
  if (newMessage.value) {
    socket.send(newMessage.value);  // 发送消息到服务器
    newMessage.value = '';  // 清空输入框
  }
};
</script>

MQTT

复制代码
// src/mqttService.js
import mqtt from 'mqtt';

let client;

export const connectMQTT = () => {
  client = mqtt.connect('wss://broker.hivemq.com:8000/mqtt');  // 替换为你的 MQTT 代理地址
  
  client.on('connect', () => {
    console.log('MQTT connected');
    client.subscribe('test/topic', (err) => {
      if (!err) {
        console.log('Subscribed to test/topic');
      }
    });
  });

  client.on('message', (topic, message) => {
    console.log(`Received message: ${message.toString()} from topic: ${topic}`);
  });
};

export const publishMessage = (topic, message) => {
  if (client && client.connected) {
    client.publish(topic, message);
    console.log(`Message sent: ${message} to topic: ${topic}`);
  }
};

export const disconnectMQTT = () => {
  if (client) {
    client.end();
    console.log('MQTT disconnected');
  }
};

<template>
  <div>
    <h1>Vue 3 with MQTT</h1>
    <button @click="sendMessage">Send Message</button>
    <p>Message: {{ receivedMessage }}</p>
  </div>
</template>

<script setup>
import { ref, onMounted, onBeforeUnmount } from 'vue';
import { connectMQTT, publishMessage, disconnectMQTT } from './mqttService';

const receivedMessage = ref('');

const sendMessage = () => {
  publishMessage('test/topic', 'Hello from Vue 3!');
};

onMounted(() => {
  connectMQTT();
});

onBeforeUnmount(() => {
  disconnectMQTT();
});

// 订阅消息并更新界面
import { watchEffect } from 'vue';
watchEffect(() => {
  // 这里可以根据接收到的消息更新UI
  // 对接收到的消息进行处理
  receivedMessage.value = 'Waiting for messages...';
});
</script>

<style scoped>
button {
  padding: 10px;
  font-size: 16px;
  margin-top: 20px;
}
</style>
相关推荐
majingming1233 小时前
FUNCTION
java·前端·javascript
A_nanda4 小时前
Vue项目升级
前端·vue3·vue2
SuperEugene4 小时前
Axios 接口请求规范实战:请求参数 / 响应处理 / 异常兜底,避坑中后台 API 调用混乱|API 与异步请求规范篇
开发语言·前端·javascript·vue.js·前端框架·axios
abigale035 小时前
【浏览器 API / 网络请求 / 文件处理】前端文件上传全流程:从基础上传到断点续传
前端·typescript·文件上传·vue cli
子兮曰5 小时前
Bun v1.3.11 官方更新全整理:新增功能、关键修复与升级验证
javascript·node.js·bun
Setsuna_F_Seiei5 小时前
AI 对话应用之页面滚动交互的实现
前端·javascript·ai编程
新缸中之脑5 小时前
追踪来自Agent的Web 流量
前端
wefly20175 小时前
从使用到原理,深度解析m3u8live.cn—— 基于 HLS.js 的 M3U8 在线播放器实现
java·开发语言·前端·javascript·ecmascript·php·m3u8
英俊潇洒美少年6 小时前
vue如何实现react useDeferredvalue和useTransition的效果
前端·vue.js·react.js
kyriewen117 小时前
给浏览器画个圈:CSS contain 如何让页面从“卡成PPT”变“丝滑如德芙”
开发语言·前端·javascript·css·chrome·typescript·ecmascript