vue和websocket实现在线聊天,引入表情插件并发送表情,详细代码
时间: 2024-01-31 21:20:44 浏览: 223
好的,以下是一个基于Vue和WebSocket的在线聊天应用,支持发送表情。
首先,需要在Vue项目中安装WebSocket:
```bash
npm install --save websocket
```
然后,在Vue组件中引入WebSocket并建立连接:
```vue
<template>
<div>
<div v-for="message in messages" :key="message.id">
<strong>{{ message.sender }}</strong>: {{ message.content }}
</div>
<input v-model="input" @keyup.enter="sendMessage" placeholder="Type a message...">
</div>
</template>
<script>
import WebSocket from 'websocket';
export default {
data() {
return {
ws: null, // WebSocket对象
messages: [], // 聊天记录
input: '', // 输入框内容
};
},
created() {
// 建立WebSocket连接
this.ws = new WebSocket('ws://localhost:8080');
this.ws.onmessage = (event) => {
const message = JSON.parse(event.data);
this.messages.push(message);
};
},
methods: {
sendMessage() {
const message = {
sender: 'me',
content: this.input,
};
this.ws.send(JSON.stringify(message));
this.messages.push(message);
this.input = '';
},
},
};
</script>
```
在上述代码中,我们建立了一个WebSocket连接,并在接收到消息时将其添加到聊天记录中。还定义了一个`sendMessage`方法,用于发送消息。
接下来,我们需要实现表情功能。这里我们使用了一个开源的表情插件emoji-mart:
```bash
npm install --save emoji-mart
```
然后,在Vue组件中引入emoji-mart并添加表情选择器:
```vue
<template>
<div>
<div v-for="message in messages" :key="message.id">
<strong>{{ message.sender }}</strong>: <span v-html="message.content"></span>
</div>
<input v-model="input" @keyup.enter="sendMessage" placeholder="Type a message...">
<div>
<emoji-mart @select="addEmoji" :native="true"></emoji-mart>
</div>
</div>
</template>
<script>
import WebSocket from 'websocket';
import { Picker } from 'emoji-mart';
export default {
components: {
'emoji-mart': Picker,
},
data() {
return {
ws: null,
messages: [],
input: '',
};
},
created() {
this.ws = new WebSocket('ws://localhost:8080');
this.ws.onmessage = (event) => {
const message = JSON.parse(event.data);
this.messages.push(message);
};
},
methods: {
sendMessage() {
const message = {
sender: 'me',
content: this.input,
};
this.ws.send(JSON.stringify(message));
this.messages.push(message);
this.input = '';
},
addEmoji(emoji) {
this.input += emoji.native;
},
},
};
</script>
```
在上述代码中,我们引入了`Picker`组件,并在页面上添加了一个表情选择器。当用户选择表情时,触发`addEmoji`方法,将表情添加到输入框中。
最后,我们需要在服务器端处理WebSocket连接和消息发送:
```javascript
const WebSocket = require('websocket').server;
const http = require('http');
const server = http.createServer((req, res) => {
res.writeHead(404);
res.end();
});
server.listen(8080);
const wsServer = new WebSocket({
httpServer: server,
});
const connections = [];
wsServer.on('request', (request) => {
const connection = request.accept(null, request.origin);
connections.push(connection);
connection.on('message', (message) => {
const data = JSON.parse(message.utf8Data);
connections.forEach((c) => {
c.sendUTF(JSON.stringify(data));
});
});
connection.on('close', () => {
connections.splice(connections.indexOf(connection), 1);
});
});
```
在上述代码中,我们创建了一个HTTP服务器和一个WebSocket服务器。当WebSocket连接请求到达时,将其添加到`connections`数组中,并在接收到消息时将其发送给所有连接。当WebSocket连接关闭时,从`connections`数组中删除该连接。
现在,我们就完成了一个基于Vue和WebSocket的在线聊天应用,支持发送表情。
阅读全文