vue使用EventSource

前后端分离项目,vue通过EventSource监听后台数据,并添加声音提示

完整代码(写在mounted):

const that = this
if (typeof (EventSource) !== 'undefined') {
    var music = new Audio()
    music.src = require('@/assets/wav/notice-short.wav')  // 声音文件
    const se = new EventSource('/message/result', { withCredentials: true }) // 后端接口,要配置允许跨域属性
    se.onopen=function(e){}
    se.onmessage=function(e){
       music.play()
       that.$notify({
         title: '打印结果',
         message: e.data,
         type: 'success'
       })
       if (sessionStorage.length === 0) { // 退出登录
         se.close()
       }
     }
     se.onerror=function(e){}
 } else {
   that.$message.error('当前浏览器不支持服务器发送的事件')
 }

1.首先判断浏览器是否支持EventSource

if (typeof (EventSource) !== 'undefined') {
  // 操作代码
 } else {
   that.$message.error('当前浏览器不支持服务器发送的事件')
 }

 2.定义EventSource对象的变量,onopen是连接的时候触发、onmessage是接收消息的时候触发、onerror是连接失败时候触发,EventSource是连接失败后会重新发起连接的。

重点是{ withCredentials: true },  因为前后端分离会产生跨域问题 


    const se = new EventSource('/message/result', { withCredentials: true })
    se.onopen=function(e){}
    se.onmessage=function(e){
       that.$notify({
         title: '打印结果',
         message: e.data,
         type: 'success'
       })
     }
     se.onerror=function(e){}

3.添加声音提示

 var music = new Audio()
 music.src = require('@/assets/wav/notice-short.wav')
 music.play()

4.运行效果 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值