el-select选中某一个之后,再选择第二个,下拉框的选中光标不能取消第一次选中的选项

el-selet,template部分

js 复制代码
<el-select v-model="condition.element.id" placeholder="请选择" @change="changeIfCoditionElement($event, ruleIndex, index)">
	 <el-option v-for="(element) in allElements" :key="element.id"  :label="element.title" :value="element.id" />
</el-select>

condition的值

js 复制代码
condition = {
    element: {
        id:""
    },
    state: '',
    choiceIndex: -1,
    startScore: null,
    endScore: null
}

allElements

js 复制代码
const allElements = computed(() => {
	return props.questionSettings.pages
		.flatMap(page => page.elements)
		.filter(element => element.type !== 'panel' && element.type !== 'html')
});

changeIfCoditionElement($event, ruleIndex, index)

ini 复制代码
const changeIfCoditionElement = (elementId, ruleIndex, index) => {
	// 改变如果条件的题目,则重置选择状态
	logicRules[ruleIndex].ifConditions[index].state = ''      
  ifCoditionElement.value = allElements.value.find(el => el.id === elementId)
	logicRules[ruleIndex].ifConditions[index].elementId = ifCoditionElement
	...
}

Bug

第一次点击选择下拉选项A,下拉框显示选项A,下拉框的选项列表中选项A变蓝 第二次点击选择下拉选项B,下拉框中显示选项A,下拉框的选项列表中选项A和选项B都变蓝

预期

第二次点击选择下拉选项B,下拉框中出现选项B,下拉框的选择列表中只有选项B变蓝

解决办法

1.去掉condition中的element对象,换成elementId并赋值为空字符串

js 复制代码
{
    elementId: "", 
    ...
}

2.在change事件中保存elementId而不是原来的element

js 复制代码
const changeIfCoditionElement = (elementId, ruleIndex, index) => {
	// 改变如果条件的题目,则重置选择状态
	logicRules[ruleIndex].ifConditions[index].state = ''
	logicRules[ruleIndex].ifConditions[index].elementId = elementId
}

这样就解决了

原因

但是,我并不知道这是什么原因,如果有大佬知道,还请留言。

相关推荐
IT_陈寒几秒前
Java性能调优实战:5个被低估却提升30%效率的JVM参数
前端·人工智能·后端
快手技术1 分钟前
AAAI 2026|全面发力!快手斩获 3 篇 Oral,12 篇论文入选!
前端·后端·算法
颜酱3 分钟前
前端算法必备:滑动窗口从入门到很熟练(最长/最短/计数三大类型)
前端·后端·算法
全栈前端老曹11 分钟前
【包管理】npm init 项目名后底层发生了什么的完整逻辑
前端·javascript·npm·node.js·json·包管理·底层原理
HHHHHY18 分钟前
mathjs简单实现一个数学计算公式及校验组件
前端·javascript·vue.js
boooooooom21 分钟前
Vue3 provide/inject 跨层级通信:最佳实践与避坑指南
前端·vue.js
一颗烂土豆21 分钟前
Vue 3 + Three.js 打造轻量级 3D 图表库 —— chart3
前端·vue.js·数据可视化
青莲84321 分钟前
Android 动画机制完整详解
android·前端·面试
iReachers24 分钟前
HTML打包APK(安卓APP)中下载功能常见问题和详细介绍
前端·javascript·html·html打包apk·网页打包app·下载功能
颜酱26 分钟前
前端算法必备:双指针从入门到很熟练(快慢指针+相向指针+滑动窗口)
前端·后端·算法