element-ui v-for循环Form表单

应用场景: 当你出现一个字段不同 数量不同的表单 你又不能写死 这时就需要v-for来循环表单

data () {
  return {
    dataForm: {
      name: 'zs',
      age: 14,
      gender: '男'
    }
  }
}

// 此时的场景 假如你不知道dataForm里面有几个字段或者字段名你不知道 此时就需要循环表单

<el-form :model="dataForm" label-position="left" inline>
  <el-form-item v-for="(item,index) in Object.keys(dataForm)" :key="index" :label="item">
    <el-input v-model="dataForm[item]"></el-input>
  </el-form-item>
</el-form>

// Object.keys() 返回一个由对象键组成的一个数组因此可以循环 而获取对象属性里有两种方式
// 第一种 dataForm.name 
// 第二种 dataForm['name']
// 而上面v-model为什么不用dataForm.item 哈哈哈这样写就错了 他会解析成第一种的获取对象属性的值固然 dataForm里面是没有item这个键的 所以会报错!!

以下是一个使用element-ui的v-for循环el-form-item的组件代码示例: ```vue <template> <el-form> <el-form-item v-for="(field, index) in fields" :key="index" :label="field.label"> <el-input v-model="field.value" :placeholder="field.placeholder"></el-input> </el-form-item> </el-form> </template> <script> export default { props: { fields: { type: Array, required: true, default: () => [], }, }, }; </script> ``` 在上述代码中,我们使用了一个props属性来接收一个名为fields的数组,该数组中包含了每个表单项的label、placeholder和value属性。我们使用v-for循环该数组,并将其作为el-form-item的子组件,每个el-form-item包含了一个el-input组件,用于输入表单项的值。最后,我们将整个表单包裹在一个el-form组件中。 使用该组件时,我们只需要传递一个包含所有表单项的数组即可: ```vue <template> <my-form :fields="fields"></my-form> </template> <script> import MyForm from "@/components/MyForm.vue"; export default { components: { MyForm, }, data() { return { fields: [ { label: "姓名", placeholder: "请输入姓名", value: "", }, { label: "邮箱", placeholder: "请输入邮箱", value: "", }, { label: "电话", placeholder: "请输入电话", value: "", }, ], }; }, }; </script> ``` 在上述代码中,我们引入了刚才创建的MyForm组件,并将fields数组传递给该组件的props属性。fields数组中包含了三个表单项,分别是姓名、邮箱和电话。我们可以通过该组件来快速创建包含多个表单项的表单。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值