创新实训(十二) 项目开发——历史对话增加查询功能

必要性

随着对话记录的增加,根据对话名称conv_name查询对话对用户来说非常有必要实现。

实现

原来的history_chats.vue中使用了getChatList() 在onMounted时直接获取用户的所有对话记录,如果要实现查询功能,需要增加两个变量:

//查询得到的记录
const currentHistory = ref(null); // 使用 ref 创建一个响应式引用  
//所有对话
const allHistory = ref(null); // 使用 ref 创建一个响应式引用  

然后更改原有的getlist方法,将allHistory的value给chatHistory,可以保留原本的总的对话记录,同时将chatHistory作为返回的记录结果:

function getChatList() {let data = { "user_id": user_id.value };return getUserAllConversation(data).then(res => {if (res.code === 200) {allHistory.value = res.data.conversations; // 使用 .value 来更新 ref 的值  allHistory.value.reverse();allHistory.value.forEach(chat => {chat.formattedCreateTime = formatDateTime(chat.create_time); // 添加一个新字段来保存格式化后的时间  });console.log(allHistory.value);chatHistory.value=allHistory.value;return true;} else {console.log(res.msg);}}).catch(e => {console.error('获取对话列表失败:', e);});
}

在html中添加输入框和查询按钮:

    <div style="display: flex; align-items: center; margin: 20px 0;"><el-input v-model="input" style="width: 60%;height: 40px;" placeholder="请输入历史记录名称进行查询" clearable></el-input><el-button type="primary"  size="large" @click="searchChatList()" style="margin-left: 10px;">查询</el-button></div>

实现的查询函数和实现思路如下

  1. 检查输入框是否为空:

    • 如果输入框为空(即 input.value.trim() 为空字符串),则调用 getChatList() 函数获取全部的聊天记录,并将其赋值给 chatHistory.value
  2. 初始化 currentHistory 变量:

    • allHistory.value 的值赋给 currentHistory.value。这里 allHistory.value 存储了所有的聊天记录。
  3. 根据关键词筛选聊天记录:

    • 如果输入框中有关键词 keyword1,则使用 filter 方法从 currentHistory.value 中筛选出 conv_name 属性包含该关键词的聊天记录,并将结果赋给 currentHistory.value
  4. 更新 chatHistory.value:

    • 最后,将 currentHistory.value 的值赋给 chatHistory.value。这样就完成了根据关键词搜索聊天记录的功能。

主要逻辑是:先初始化 currentHistory 为全部聊天记录,然后根据用户输入的关键词,筛选出匹配的聊天记录,并更新 currentHistory,最后将 currentHistory 的值赋给 chatHistory,以供其他地方使用。

//进行搜索,替换当前的结果
const searchChatList = () =>{if(input.value.trim()===''){//为空返回全部getChatList();return;}const keyword1 =input.value.trim()// const list = JSON.parse(localStorage.getItem('list') as string)currentHistory.value = allHistory.valueif (keyword1) {currentHistory.value = currentHistory.value.filter(item => item.conv_name.includes(keyword1));}chatHistory.value = currentHistory.value;}

最终实现效果如下:

在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/32938.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【STM32入门学习】基于DHT20温湿度传感器数据采集和显示

目录 一、软件I2C和硬件I2C 1.1硬件I2C 1.2软件I2C 二、创建工程&#xff08;基于HAL库&#xff09; 三、实物连线 3.1DHT20 3.2串口传输&#xff1a; 四、结果演示 4.1部署文件 4.2主要代码分析 五、心得体会 一、软件I2C和硬件I2C I2C 基本读写过程: 其中S表示由主…

Android Basis - Google Keybox

什么是Keybox Android O 开始谷歌要求每台机器预制谷歌提供的 Attestion Key的需求&#xff0c;该需求要求,每台机器都预制谷歌提供的 key&#xff0c;因此需要 oem 厂商在工厂完成预制。没有预制该key 将直接导致机器 cts 相关测试项失败。Google attestation key的集合又称作…

Spring AI 介绍以及与 Spring Boot 项目整合

Spring AI 项目旨在简化使用 Spring Boot 开发包含人工智能功能的应用程序&#xff0c;提供抽象和支持多种模型提供商及矢量数据库提供商。 Spring AI 的功能特点 支持主流模型提供商&#xff1a;如 OpenAI、Microsoft、Amazon、Google 和 Huggingface 等。支持多种模型类型&a…

RDB总结

RDB总结 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 什么是RDB&#xff1f; RDB&#xff08;Relational Database&#xff09;即关系型数据库&#xff0c…

Retrieval-Augmented Generation for Large Language Models A Survey

Retrieval-Augmented Generation for Large Language Models: A Survey 文献综述 文章目录 Retrieval-Augmented Generation for Large Language Models: A Survey 文献综述 Abstract背景介绍 RAG概述原始RAG先进RAG预检索过程后检索过程 模块化RAGModules部分Patterns部分 RAG…

phpcms网站模板收费下载站素材图片网站源码

★模板介绍★ 本套源码&#xff0c;主要针对资源下载&#xff0c;素材/图片/模板/源码/插件/ 我们已经对源码进行了多处二次开发&#xff0c;对模板进行了深度优化&#xff0c;没有多余的无用代码。更符合收费下载站行业的标准&#xff0c;保证每位站长购买后多能直接用上&am…

Python | Leetcode Python题解之第187题重复的DNA序列

题目&#xff1a; 题解&#xff1a; L 10 bin {A: 0, C: 1, G: 2, T: 3}class Solution:def findRepeatedDnaSequences(self, s: str) -> List[str]:n len(s)if n < L:return []ans []x 0for ch in s[:L - 1]:x (x << 2) | bin[ch]cnt defaultdict(int)for…

vue中用JSON格式查看数据(vue-json-viewer)

vue中把string用JSON格式展示数据 vue-json-viewer使用 官网地址&#xff1a;https://www.npmjs.com/package/vue-json-viewer 1. 安装插件vue-json-viewer //vue2 npm install vue-json-viewer2 --save //vue3 npm install vue-json-viewer3 --save2. 引入vue-json-viewer…

星闪指向遥控,做家电交互的破壁人

“面壁者罗辑&#xff0c;我是你的破壁人。” 科幻小说《三体》中&#xff0c;当人类的基础科学被三体人封锁&#xff0c;变得停步不前&#xff0c;人类启动了自救的面壁计划&#xff0c;通过一次又一次破壁&#xff0c;找到战胜三体人的办法。 现实中&#xff0c;有一点已经成…

边缘计算设备有哪些

边缘设备是指那些位于数据源附近&#xff0c;能够执行数据处理、分析和决策的计算设备。这些设备通常具有一定的计算能力、存储能力和网络连接能力&#xff0c;能够减少数据传输到云端的需要&#xff0c;从而降低延迟、节省带宽并提高数据处理的效率。以下是一些常见的边缘设备…

Html去除a标签的默认样式

Html去除a标签的默认样式, a标签超链接字体默认蓝色带下划线; 去除可用: a{text-decoration:none;color:inherit;cursor:auto; }测试代码 <!DOCTYPE html> <html lang"zh-CN" dir"ltr"><head><meta charset"utf-8"/>&…

上海交大阿里巴巴推出虚拟试衣新里程碑式工作——AnyFit:任意场景、任意组合!

文章链接&#xff1a;https://arxiv.org/pdf/2405.18172 工程链接&#xff1a;https://colorful-liyu.github.io/anyfit-page/ 今天和大家一起学习的是一种名为AnyFit的新型虚拟试穿系统&#xff0c;旨在解决现有技术在处理不同场景和服饰组合时出现的衣物风格不匹配和质量下…

lvs负载均衡dr模式实验

lvs研发者章文嵩 lvs 红帽内核标配 client --->负载均衡器--->web服务器(nginx apache) nginx也可以当作负载均衡器 7层负载 需要在反向代理的配置基础上添加配置 >负载均衡的作用是什么? 1流量分发 2后端的单个服务器可以降低配置 3防止单节点故障 >web代理服务…

【MySQL】Linux中MySQL的使用及配置

一、字符集修改 1、MySQL8.0之前&#xff0c;字符集都默认是latin1&#xff0c;从MySQL8.0开始&#xff0c;字符集utf8mb4&#xff0c;这意味着&#xff0c;在默认情况下&#xff0c;MySQL8.0之前都是不支持中文的 # 查看字符集信息&#xff0c;主要是character_set_server和…

能正常执行但是 cion 标红/没有字段提示

ctrl q 退出 clion 找到工程根目录&#xff0c;删除隐藏文件 .idea 再重新打开 clion 标红消失&#xff0c;同时再次输入函数/类属性&#xff0c;出现字段提示 clion 的智能提示方案存储在 .idea 文件中&#xff0c;如果工程能够正常编译执行&#xff0c;那么说明是智能提示…

【JavaSE ⑧】P219 ~ 225 Date类‘’DateFormat类转化Date和字符串;Calendar类获得日历中某值,修改日历,日历转日期

目录 日期时间类1 Date类概述常用方法 2DateFormat类构造方法格式规则常用方法parse方法format方法 3 Calendar类概念获取方式常用方法get/set方法add方法getTime方法 ● 练习1.判断Date不同参数构造的输出2. 用日期时间相关的API&#xff0c;计算一个人已经出生了多少天。3. 获…

技术管理转型之战:解锁管理新境界——直觉决策的艺术与科学

文章目录 引言一、直觉决策的定义与特点二、直觉决策在管理中的价值三、直觉决策的来源1、潜意识的心里过程2、基于价值观或道德的决策3、基于经验的决策4、影响发动的决策5、基于认知的决策 四、如何培养直觉决策能力五、直觉决策的风险与应对结语 引言 在快速变化的商业环境…

sh脚本模块笔记

sh脚本模块笔记 1. 如果不存在&#xff0c;则创建指定目录2. 检测python启动指令 记录一些sh脚本中用到过的模块 1. 如果不存在&#xff0c;则创建指定目录 这个脚本首先会检查指定的目录是否存在&#xff0c;如果存在则会打印错误消息并退出&#xff0c;否则会创建该目录&am…

[FreeRTOS 内部实现] 创建任务 xTaskCreate函数解析

文章目录 创建任务 xTaskCreate函数原型栈深度 usStackDepth 大小如何确定任务堆空间分配 任务控制块 TCB 创建任务 xTaskCreate函数原型 BaseType_t xTaskCreate( TaskFunction_t pxTaskCode,const char * const pcName,const configSTACK_DEPTH_TYPE usStackDepth,void *…

JVM专题三:Java代码如何运行

通过前面的第一篇文章&#xff0c;对JVM整体脉络有了一个大概了解。第二篇文章我们通过对高级语言低级语言不同特性的探讨引出了Java的编译过程。有了前面的铺垫&#xff0c;咱们今天正式进入Java到底是如何运行起来的探讨。 目前大部分公司都是使用maven作为包管理工具&#x…