赞
踩
有些时候页面上有太多的表单元素,一个个的写太过繁琐,拿 input 框举例,众多的 input 框,无非就是输入框前的说明和 input 框的 name 属性不一样
<el-form :inline="true" :model="formInline" size="mini" class="demo-form-inline">
<el-form-item label="姓名">
<el-input v-model="formInline.name1" placeholder="请输入姓名"></el-input>
</el-form-item>
<!-- 当然,这里的性别应该下拉框,这里只做演示 -->
<el-form-item label="性别">
<el-input v-model="formInline.sex1" placeholder="请选择性别"></el-input>
</el-form-item>
<el-form-item label="年龄">
<el-input v-model="formInline.age1" placeholder="请输入年龄"></el-input>
</el-form-item>
</el-form>
既然这样,何不弄一个数组,通过 for 循环遍历出来,岂不是更省事?经过一番尝试,终于成功,特此记录,便于后续回顾及帮助到有需要的人。
模拟如下数据:
export default {
name: 'BasicInfo',
components: {},
data() {
return {
formInline: {
},
formData: [
{"id":"1","label":"姓名","tableColumn":"name","placeholder":""},
{"id":"2","label":"性别","tableColumn":"sex","placeholder":"请选择性别"},
{"id":"3","label":"年龄","tableColumn":"age","placeholder":"请输入年龄"}
]
}
},
}
页面也改成 v-for 来遍历
<el-form :inline="true" :model="formInline" size="mini" class="demo-form-inline">
<el-form-item
v-for="item in formData"
:index="item.id"
:key="item.id"
:label="item.label"
>
<el-input
v-model="item.tableColumn"
:placeholder="item.placeholder"
></el-input>
</el-form-item>
</el-form>
参考了几篇网友的解答
vue.js中 v-for 下的v-model 双向绑定失效的解决方法
v-for渲染input的坑!!!vue中v-for出来的input如何实现双向绑定
vue for循环v-model双向绑定对象/数组失效
后面自己试了下,改了下 v-bind 处的写法后,就可以了
<el-form :inline="true" :model="formInline" size="mini" class="demo-form-inline">
<el-form-item
v-for="item in formData"
:index="item.id"
:key="item.id"
:label="item.label"
>
<el-input
v-model="formInline[item.tableColumn]"
:placeholder="item.placeholder"
></el-input>
</el-form-item>
</el-form>
借助 Vue 开发工具可以看到,已经实现了双向绑定
看了前面几篇博客,有的往 标签里动态绑定了一个 prop 属性,刚开始不清楚啥意思,看了下文档说用于表单校验和重置表单的
于是就做了下测试:
<el-form-item v-for="item in formData" :index="item.id" :key="item.id" :label="item.label" :prop="item.tableColumn" :required="item.required" inline-message="true" :rules="{ required: true, message: `${item.label}不能为空`}" > <!-- :rules="[ { required: true, message: '年龄不能为空'}, { type: 'number', message: '年龄必须为数字值'}, { required: true, message: '请输入邮箱地址', trigger: 'blur' }, { type: 'email', message: '请输入正确的邮箱地址', trigger: ['blur', 'change'] } ]" --> <el-input v-model="formInline[item.tableColumn]" :placeholder="item.placeholder" ></el-input> </el-form-item>
结果证实了
此问题参考了这篇文章:
The label’s for attribute doesn’t match any element id…的解决办法
打开浏览器开发者工具,可以看到,vue文件里的 最终被解析成了
<el-input
v-model="formInline[item.tableColumn]"
:placeholder="item.placeholder"
:id="item.tableColumn"
></el-input>
The End!感谢参考的这几篇文章的作者,正是因为有你们的分享,像我这样的小白遇到问题时才得已解决,所以我也向你们学习,将遇到的问题记录下来,以加深印象,也能让需要的人得到参考!
由于时间有限,此例子可以做得更好,比如:动态实现下拉框、多选等…,类似代码生成器那种,有时间了琢磨下后再记录!
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。