目标:配置路由和分析结构
1)路由配置
{
path: '/room',
component: () => import('@/views/room/index.vue'),
meta: { title: '问诊室' }
},
目标:了解问诊室消息卡片类型
组件 Room/components/RoomMessage.vue
<div class="msg msg-illness">
<div class="patient van-hairline--bottom">
<p>李富贵 男 31岁p>
<p>一周内 | 未去医院就诊p>
div>
<van-row>
<van-col span="6">病情描述van-col>
<van-col span="18">头痛、头晕、恶心van-col>
<van-col span="6">图片van-col>
<van-col span="18">点击查看van-col>
van-row>
div>
<div class="msg msg-tip">
<div class="content">
<span class="green">温馨提示:span>
<span>在线咨询不能代替面诊,医护人员建议仅供参考span>
div>
div>
<div class="msg msg-tip">
<div class="content">
<span>医护人员正在赶来,请耐心等候span>
div>
div>
<div class="msg msg-to">
<div class="content">
<div class="time">20:12div>
<div class="pao">大夫你好?div>
div>
<van-image src="https://yjy-oss-files.oss-cn-zhangjiakou.aliyuncs.com/tuxian/popular_3.jpg" />
div>
<div class="msg msg-to">
<div class="content">
<div class="time">20:12div>
<van-image
fit="contain"
src="https://yjy-oss-files.oss-cn-zhangjiakou.aliyuncs.com/tuxian/popular_3.jpg"
/>
div>
<van-image src="https://yjy-oss-files.oss-cn-zhangjiakou.aliyuncs.com/tuxian/popular_3.jpg" />
div>
<div class="msg msg-from">
<van-image src="https://yjy-oss-files.oss-cn-zhangjiakou.aliyuncs.com/tuxian/popular_3.jpg" />
<div class="content">
<div class="time">20:12div>
<div class="pao">哪里不舒服div>
div>
div>
<div class="msg msg-recipe">
<div class="content">
<div class="head van-hairline--bottom">
<div class="head-tit">
<h3>电子处方h3>
<p>原始处方 <van-icon name="arrow">van-icon>p>
div>
<p>李富贵 男 31岁 血管性头痛p>
<p>开方时间:2022-01-15 14:21:42p>
div>
<div class="body">
<div class="body-item" v-for="i in 2" :key="i">
<div class="durg">
<p>优赛明 维生素E乳p>
<p>口服,每次1袋,每天3次,用药3天p>
div>
<div class="num">x1div>
div>
div>
<div class="foot"><span>购买药品span>div>
div>
div>
<div class="msg msg-tip msg-tip-cancel">
<div class="content">
<span>订单取消span>
div>
div>
小结:
目标:认识websocket
什么是 websocket ? https://websocket.org/
为什么需要websocket ?
理解 websokect 通讯过程
了解 websocket api含义
// 创建ws实例,建立连接
var ws = new WebSocket("wss://javascript.info/article/websocket/demo/hello");
// 连接成功事件
ws.onopen = function(evt) {
console.log("Connection open ...");
// 发送消息
ws.send("Hello WebSockets!");
};
// 接受消息事件
ws.onmessage = function(evt) {
console.log( "Received Message: " + evt.data);
// 关闭连接
ws.close();
};
// 关闭连接事件
ws.onclose = function(evt) {
console.log("Connection closed.");
};
说明:我们项目中使用 socket.io-client 来实现客户端代码,它是基于 websocket 的库。
目的:掌握 socket.io 的基本使用
如何使用客户端js库?
pnpm add socket.io-client
如何建立连接?
import { io } from 'socket.io-client'
// 参数1:不传默认是当前服务域名,开发中传入服务器地址
// 参数2:配置参数,根据需要再来介绍
const socket = io()
如何确定连接成功?
socket.on('connect', () => {
// 建立连接成功
})
如何发送消息?
// chat message 发送消息事件,由后台约定,可变
socket.emit('chat message', '消息内容')
如何接收消息?
// chat message 接收消息事件,由后台约定,可变
socket.on('chat message', (ev) => {
// ev 是服务器发送的消息
})
如何关闭连接?
// 离开组件需要使用
socket.close()
小结:
io('地址')
connect
emit
+ 事件on
+ 事件close()
知道前后端ws通信事件以及定义数据的类型
chatMsgList
接收聊天记录
sendChatMsg
发送消息
receiveChatMsg
接收消息
statusChange
接收订单状态改变
enums/index.ts
// 消息类型
export enum MsgType {
// 文字
MsgText = 1,
// 图片
MsgImage = 4,
// 患者
CardPat = 21,
// 处方
CardPre = 22,
// 未评价
CardEvaForm = 23,
// 已评价
CardEva = 24,
// 通用系统
Notify = 31,
// 温馨提示
NotifyTip = 32,
// 取消订单
NotifyCancel = 33
}
// 处方状态
export enum PrescriptionStatus {
// 未支付
NotPayment = 1,
// 已支付
Payment = 2,
// 无效
Invalid = 3
}
// 问诊订单状态
export enum OrderType {
// ----------------问诊订单------------------
// 待支付
ConsultPay = 1,
// 待接诊
ConsultWait = 2,
// 咨询中
ConsultChat = 3,
// 已完成
ConsultComplete = 4,
// 已取消
ConsultCancel = 5,
// ----------------药品订单------------------
// 待支付
MedicinePay = 10,
// 待发货
MedicineSend = 11,
// 待收货
MedicineTake = 12,
// 已完成
MedicineComplete = 13,
// 已取消
MedicineCancel = 14
}
types/room.d.ts
import { MsgType, PrescriptionStatus } from '@/enums'
import type { Consult, Image } from './consult'
import type { Patient } from './user'
// 1. 聊天-消息中包含处方和药品类型
// 药品
export type Medical = {
id: string
name: string
amount: string
avatar: string
specs: string
// 用量
usageDosag: string
quantity: string
// 是否是处方药
prescriptionFlag: 0 | 1
}
// 处方
export type Prescription = {
id: string
orderId: string
createTime: string
name: string
recordId: string
gender: 0 | 1
genderValue: string
age: number
// 诊断信息
diagnosis: string
status: PrescriptionStatus
// 药品订单
medicines: Medical[]
}
// 2. 聊天-评价医生
export type EvaluateDoc = {
id?: string
score?: number
content?: string
createTime?: string
creator?: string
}
// 3. 聊天-消息类型
// 消息类型:聊天-接收对话信息api
export type Message = {
id: string
msgType: MsgType
// 发消息的人ID
from?: string
fromAvatar?: string
// 收消息的人ID
to?: string
toAvatar?: string
createTime: string
// 具体消息内容
msg: {
// 文字类型
content?: string
// 图片类型
picture?: Image
// 患者卡片
consultRecord?: Consult & {
patientInfo: Patient
}
// 处方信息
prescription?: Prescription
// 评价信息
evaluateDoc?: EvaluateDoc
}
// 是否需要滚动
notScroll?: boolean
}
// 消息分组:聊天-查询历史聊天记录api
export type TimeMessages = {
createTime: string
items: Message[]
orderId: string
sid: string
}
实现:问诊app和后台ws服务建立连接
步骤:
代码:
pnpm add sokect.io-client
views/room/index.vue
import { onMounted, onUnmounted } from 'vue'
import { useUserStore } from '@/stores'
import { useRoute } from 'vue-router'
import { io, type Socket } from 'socket.io-client'
import { baseURL } from '@/utils/request'
const store = useUserStore()
const route = useRoute()
let socket: Socket
// 组件销毁时关闭连接
onUnmounted(() => {
socket.close()
})
// 组件挂载建立连接
onMounted(async () => {
// 建立链接,创建 socket.io 实例
socket = io(baseURL, {
auth: {
token: `Bearer ${store.user?.token}``
},
query: {
orderId: route.query.orderId
}
})
// 如果连接建立成功就会执行这个函数
socket.on('connect', () => {
// 建立连接成功
console.log('connect')
})
// 捕捉错误
socket.on('error', (event) => {
// 错误异常消息
console.log('error')
})
// 断开连接时执行这里
socket.on('disconnect', ()=> {
// 已经断开连接
console.log('disconnect')
})
})