0

0

如何实现聊天记录编辑功能的互斥效果?

碧海醫心

碧海醫心

发布时间:2025-03-24 10:50:25

|

370人浏览过

|

来源于php中文网

原创

问题介绍

在实现聊天记录编辑功能时,用户希望在点击一条聊天记录进行编辑后,再点击另一条记录时,前一条记录的编辑状态能够关闭,实现互斥效果。然而,实际效果却是所有点击的记录都会同时展示编辑框,无法达到预期的互斥效果。

具体实现过程

子组件:


esc键取消 · 回车键保存

子组件 script 内主要代码:

const props = defineprops()
const emit = defineemits<{
    (event: 'menuclick', value: string, item: object): void
}>()
const menuitems = [
    {
        id: '1',
        icon: 'finished',
        title: $t('text_multiple_choice')
    },
    {
        id: '2',
        icon: 'edit',
        title: $t('btn_edit')
    },
    {
        id: '3',
        icon: 'chatdotsquare',
        title: $t('btn_reply')
    }
]

// 处理菜单项点击事件
const editcontent = ref('')
const changemsgid = ref('')
const currentediting = ref(false) //用来标记表单是否正在提交
const handleselect = (val: string) => {
    if(val === '1') {
        props.dialogdata.checked = true
    } else if (val === '2') {
        console.log('--handleselect---2', props.dialogdata);
        props.dialogdata.isediting = true
        currentediting.value = false
        editcontent.value = props.dialogdata.content
        changemsgid.value = props.dialogdata.msg_id
    }
    emit('menuclick', val, props.dialogdata)
}

父组件使用:

messagelist 的数据格式:

[
    {
        "msg_id": "1276491426334769232",
        "content": "啊撒大声地",
        "checked": false
    },
    {
        "msg_id": "1276493284222701702",
        "content": "asdasdaasdsadasd",
        "checked": false
    },
    ...省略
]

父组件 script 主要方法:

奇布塔
奇布塔

基于AI生成技术的一站式有声绘本创作平台

下载
const handlemenuclick = (val: string, dialogdata: any) => {
    if(val === '1') {
        messagelist.value.foreach((item) => {
            item.checked = true
        })
        showrecords.value = true
        showreplymsg.value = false
        dialogdata.showeditcontent = false
    } else if(val === '2') {
        showreplymsg.value = false
        replyauthor.value = ''
        showrecords.value = false
        dialogdata.showeditcontent = true
    } else if(val === '3') {
        showreplymsg.value = true
        dialogdata.showeditcontent = false
        replyauthor.value = dialogdata.author.username
        replycontent.value = dialogdata.content
    }
}

问题解决方案

问题在于,当用户点击不同的聊天记录时,showeditcontent 属性并没有互斥地关闭其他记录的编辑状态。解决这个问题需要在父组件中维护一个全局的编辑状态,并在每次点击编辑时,关闭其他记录的编辑状态。

可以修改父组件中的 handlemenuclick 方法如下:

const handleMenuClick = (val: string, dialogData: any) => {
    if(val === '1') {
        messageList.value.forEach((item) => {
            item.checked = true
            item.showEditContent = false // 确保关闭所有编辑状态
        })
        showRecords.value = true
        showReplyMsg.value = false
        dialogData.showEditContent = false
    } else if(val === '2') {
        messageList.value.forEach((item) => {
            item.showEditContent = false // 关闭其他记录的编辑状态
        })
        showReplyMsg.value = false
        replyAuthor.value = ''
        showRecords.value = false
        dialogData.showEditContent = true // 仅打开当前记录的编辑状态
    } else if(val === '3') {
        messageList.value.forEach((item) => {
            item.showEditContent = false // 确保关闭所有编辑状态
        })
        showReplyMsg.value = true
        dialogData.showEditContent = false
        replyAuthor.value = dialogData.author.username
        replyContent.value = dialogData.content
    }
}

通过上述修改,每次点击编辑时,都会先关闭所有其他记录的编辑状态,再打开当前记录的编辑状态,从而实现互斥的效果。

相关专题

更多
菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

0

2026.01.22

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

56

2026.01.21

三角洲入口地址合集
三角洲入口地址合集

本专题整合了三角洲入口地址合集,阅读专题下面的文章了解更多详细内容。

51

2026.01.21

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

397

2026.01.21

妖精漫画入口地址合集
妖精漫画入口地址合集

本专题整合了妖精漫画入口地址合集,阅读专题下面的文章了解更多详细内容。

118

2026.01.21

java版本选择建议
java版本选择建议

本专题整合了java版本相关合集,阅读专题下面的文章了解更多详细内容。

3

2026.01.21

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

16

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

11

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 2.9万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.5万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号