vue2+elementUI,vue3+elementPlus解决form中的下拉列表回写显示id,不显示label

三个问题:

问题1:vue2+elementui中form下的下拉列表回写,赋值之后会出现更改不了值的情况
问题2:表单中绑定的值是v-model='form.father.son' 这种多级响应不了,把这种多级改成单级 v-model='form.son' 就不会出现值更改不了的情况
问题3:vue3+elementPlus 表单基础多选,回写的时候显示的是id 不是label名称,因为我的类型错误导致的

如下:

问题1:vue2+elementui中form下的下拉列表回写,赋值之后会出现更改不了值的情况,原因是我之前的赋值方式是

问题代码:

javascript 复制代码
edit(row){
	//显示弹窗
	this.centerDialogVisible = true
	// 给表单中的输入框赋值
	this.form.title=row.title
	// 给表单中的下拉框赋值
	this.form.teacher_id=row.teacher_id
}

更改之后的代码:

javascript 复制代码
edit(row){
	//显示弹窗
	this.centerDialogVisible = true
	
	this.form={
		title:row.title,// 给表单中的输入框赋值
		teacher_id:row.teacher_id// 给表单中的下拉框赋值
	}


}

问题2:表单中绑定的值是v-model='form.father.son' 这种多级响应不了,把这种多级改成单级 v-model='form.son' 就不会出现值更改不了的情况

问题3:vue3+elementPlus 表单基础多选,回写的时候显示的是id 不是label名称,因为我的类型错误导致的

后端给的数据是字符串类型的 1,4,3,2

但是elementplus中需要的是数字类型的数组

直接字符串转数组,转出来的类型是 ['1','4','3','2']

需要把数组中的字符串转成数字类型 [1,4,3,2],使用.map(Number) 方法

问题代码:

javascript 复制代码
 ruleForm.template_ids = row.template_id ? row.template_id.split(',') : []

正确代码:

javascript 复制代码
 <el-form ref="ruleFormRef" :model="ruleForm" >
	<el-form-item label="选择模板:" prop="">
	  <el-select v-model="ruleForm.template_ids" filterable multiple placeholder="请选择/输入"
	 >
	      <el-option :label="item.template_title" :value="item.id" v-for="(item, index) in mubanArr"
	          :key="index"></el-option>
	  </el-select>
	</el-form-item>
</el-form>
javascript 复制代码
		let template_id = row.template_id.split(',') // ['1','4','3','2']
        let xx = template_id.map(Number) //  [1,4,3,2]
        ruleForm.template_ids = xx.length > 0 ? xx : [] //给表单赋值回写

vue3中表单的回写方式如下:(不是写在一起,单独排列开)

javascript 复制代码
ruleForm.title = row.title
ruleForm.teacher_id = row.teacher_id

这是我自己实验出来的代码,效果是好的,如有不足或者有更好的方法,欢迎指正探讨

相关推荐
candyTong7 小时前
一觉醒来,大模型就帮我排查完页面性能问题
前端·javascript·架构
魔术师Grace7 小时前
我给 AI 做了场入职培训
前端·程序员
玩嵌入式的菜鸡8 小时前
网页访问单片机设备---基于mqtt
前端·javascript·css
前端一小卒8 小时前
我用 Claude Code 的 Superpowers 技能链写了个服务,部署前差点把服务器搞炸
前端·javascript·后端
滑雪的企鹅.9 小时前
HTML头部元信息避坑指南大纲
前端·html
一拳不是超人9 小时前
老婆天天吵吵要买塔罗牌,我直接用 AI 2 小时写了个在线塔罗牌
前端·ai编程
excel11 小时前
如何解决 Nuxt DevTools 中关于 unstorage 包的报错
前端
Rust研习社11 小时前
使用 Axum 构建高性能异步 Web 服务
开发语言·前端·网络·后端·http·rust
C澒11 小时前
AI 生码 - API2Code:接口智能匹配与 API 自动化生码全链路设计
前端·低代码·ai编程
浔川python社11 小时前
HTML头部元信息避坑指南技术文章大纲
前端·html