当前位置:首页 > 文章列表 > 文章 > 前端 > Vue3点击消息仅显示当前编辑框方法

Vue3点击消息仅显示当前编辑框方法

2025-04-03 13:45:26 0浏览 收藏

本文介绍了在Vue3中实现聊天记录编辑功能时遇到的问题及解决方案。由于每次点击编辑消息时,所有消息的编辑框都会显示,文章分析了原因:父组件控制的`showeditcontent`属性未能实现编辑框的互斥显示。解决方法是修改父组件的`handlemenuclick`函数,在点击编辑新消息前,先将所有消息的`showeditcontent`属性设置为`false`,确保只有一个消息的编辑框可见。文章通过代码示例详细讲解了子组件和父组件的交互,以及数据结构的设计,最终实现了点击消息时仅显示当前消息编辑框的功能,有效解决了Vue3中编辑框显示的冲突问题。

vue3中为什么id是唯一的,input却同时会展示?

在使用vue3开发聊天记录编辑功能时,我们遇到了一个问题:虽然每个消息的id是唯一的,但每次点击不同的消息进行编辑时,所有被编辑的消息都显示出来了,而不是只有当前点击的消息显示编辑框。这个问题让我非常困惑,因为我已经确保了每个消息的meg_id是独立的,并且在点击时也正确获取到了meg_id。

问题描述如下:我想实现的是,当点击第一条消息进行编辑时,点击第二条消息时,第一条消息的编辑框应该关闭,只显示第二条消息的编辑框,达到互斥的效果。

以下是具体的实现过程:

子组件代码


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部分:

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函数会将该消息的showeditcontent设置为true。但是,这并没有关闭其他消息的编辑框。

要达到互斥的效果,我们需要在点击新的消息进行编辑时,将所有其他消息的showeditcontent设置为false。可以修改父组件的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
  } 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
    replyAuthor.value = dialogData.author.username
    replyContent.value = dialogData.content
  }
}

通过以上修改,每次点击新的消息进行编辑时,其他消息的编辑框都会被关闭,从而达到互斥的效果。这样,id虽然是唯一的,但input框的展示也会如我们期望的那样,只显示当前点击的消息的编辑框。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。

Vue.js异步操作技巧与实战案例Vue.js异步操作技巧与实战案例
上一篇
Vue.js异步操作技巧与实战案例
蓝思科技2024年营收猛增至698.97亿,涨28.27%
下一篇
蓝思科技2024年营收猛增至698.97亿,涨28.27%
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 笔灵AI生成答辩PPT:高效制作学术与职场PPT的利器
    笔灵AI生成答辩PPT
    探索笔灵AI生成答辩PPT的强大功能,快速制作高质量答辩PPT。精准内容提取、多样模板匹配、数据可视化、配套自述稿生成,让您的学术和职场展示更加专业与高效。
    23次使用
  • 知网AIGC检测服务系统:精准识别学术文本中的AI生成内容
    知网AIGC检测服务系统
    知网AIGC检测服务系统,专注于检测学术文本中的疑似AI生成内容。依托知网海量高质量文献资源,结合先进的“知识增强AIGC检测技术”,系统能够从语言模式和语义逻辑两方面精准识别AI生成内容,适用于学术研究、教育和企业领域,确保文本的真实性和原创性。
    35次使用
  • AIGC检测服务:AIbiye助力确保论文原创性
    AIGC检测-Aibiye
    AIbiye官网推出的AIGC检测服务,专注于检测ChatGPT、Gemini、Claude等AIGC工具生成的文本,帮助用户确保论文的原创性和学术规范。支持txt和doc(x)格式,检测范围为论文正文,提供高准确性和便捷的用户体验。
    37次使用
  • 易笔AI论文平台:快速生成高质量学术论文的利器
    易笔AI论文
    易笔AI论文平台提供自动写作、格式校对、查重检测等功能,支持多种学术领域的论文生成。价格优惠,界面友好,操作简便,适用于学术研究者、学生及论文辅导机构。
    47次使用
  • 笔启AI论文写作平台:多类型论文生成与多语言支持
    笔启AI论文写作平台
    笔启AI论文写作平台提供多类型论文生成服务,支持多语言写作,满足学术研究者、学生和职场人士的需求。平台采用AI 4.0版本,确保论文质量和原创性,并提供查重保障和隐私保护。
    40次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码