创新实训(十四) 项目开发——用户终止对话功能bug修复

bug分析

创新实训(十三) 项目开发——实现用户终止对话功能

上面的实现在后面的测试中发现有问题,当前的问题被终止后,提问下一个问题,后端已经显示了回答,前端也可以在network界面看到流式的回答,但是UI界面就是没有输出。

重新回顾上述实现,发现mixchat接口在调用stopchat接口后,仍然收到后端的sse消息,导致上一个回答还未终止,下一个回答的message已经来到,而mixchat从未abort,进一步导致了接收到的message混乱。

根本原因是**:每一次用户的query其实都是使用的最初建立的sse连接**。

修改如下

首先对变量controller和siginal进行修改:

let controller = ref(null);
controller.value = new AbortController();
const signal = ref(controller.value.signal);

使用ref可以动态的监听变化。

在onsend方法中,对于点击停止的按钮处理,在接口返回ok后,新建一个controller.value。

//直接断掉上一次的sse连接
controller.value= new AbortController();
signal.value =controller.value.signal;

同时增加判断:

  • 如果用户选择点击停止,进入changewait方法
  • 否则就视为开启新的对话,将isUserAbort.value设为false
if(button.value.type==='info'){

    button.value.status=true;
    changeWait();
    
    return ;
  }

  //如果用户再次点击发送,再在用户中断设为false
  else  isUserAbort.value===false;

终止的关键还是在controller.value.abort();

    controller.value.abort(); //连接没有被完全断开欸
    signal.value=controller.value.signal;
    console.log(signal.value);

实现效果如下

  • 第一种情况:
    在这里插入图片描述
    查看网络:调用stop后mix-chat直接被中断
    在这里插入图片描述
  • 第二种情况:
    在这里插入图片描述
    响应在只有docs时被终止:
    在这里插入图片描述
    在这里插入图片描述
  • 第三种情况
    在这里插入图片描述
    mix-chat已经返回了部分回答后被终止
    在这里插入图片描述
    在这里插入图片描述
  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值