应用场景:
在实际使用中经常会遇到需要在Form表单中使用table表格进行表单提交,同时又需要对table的字段进行校验,效果如图所示:
这个校验中,最关键的问题在于如何给el-form-item 动态绑定prop。
:prop="'tableData.' + scope.$index + '.字段名'"
方法一:
<template> <div class="app-container"> <el-form :model="fromData" ref="from"> <el-table :data="fromData.domains"> <el-table-column label="姓名"> <template slot-scope="scope"> <el-form-item :prop="'domains.'+scope.$index+'.name'" :rules="fromaDataRules.name"> <el-input v-model="scope.row.name"></el-input> </el-form-item> </template> </el-table-column> <el-table-column label="地址"> <template slot-scope="scope"> <el-form-item :prop="'domains.'+scope.$index+'.desc'" :rules="fromaDataRules.desc"> <el-input v-model="scope.row.desc"></el-input> </el-form-item> </template> </el-table-column> </el-table> </el-form> <el-button type="warning" @click="submit('from')">submit</el-button> </div> </template> <script> export default { data() { return { fromData:{ domains:undefined }, fromaDataRules:{ name:[{ required: true, message: '请输入', trigger: 'blur' }], desc:[ { required: true, message: '请填写', trigger: 'blur' }] }, domains:[], } }, mounted(){ this.initDomains() }, methods:{ initDomains(){ this.domains=[ { name: "小红", desc: "11123" }, { name: "小红", desc: "11123" } ] }, init(){ this.$set(this.fromData,'domains',this.domains) }, submit(formName){ this.$refs[formName].validate((valid) => { if (valid) { alert('submit!'); } else { console.log('error submit!!'); return false; } }); } } } </script>
上述代码中比较关键的部分有一下两点:
1、:prop="‘domains.'+scope.$index+'.name'" ,用于动态绑定prop到el-form-item;
2、this.$set(this.fromData,‘domains',this.domains) ,用于为fromData设置domains这个节点。
方法二:
<template> <div class="app-container"> <el-form :model="fromData" ref="from"> <el-table :data="fromData.domains"> <el-table-column label="姓名"> <template slot-scope="scope"> <el-form-item :prop="'domains.'+scope.$index+'.name'" :rules="fromData.fromaDataRules.name"> <el-input v-model="scope.row.name"></el-input> </el-form-item> </template> </el-table-column> <el-table-column label="地址"> <template slot-scope="scope"> <el-form-item :prop="'domains.'+scope.$index+'.desc'" :rules="fromData.fromaDataRules.desc"> <el-input v-model="scope.row.desc"></el-input> </el-form-item> </template> </el-table-column> </el-table> </el-form> <el-button type="warning" @click="submit('from')">submit</el-button> </div> </template> <script> export default { data() { return { fromData:{ fromaDataRules:{ name:[{ required: true, message: '请输入', trigger: 'blur' }], desc:[ { required: true, message: '请填写', trigger: 'blur' }] }, domains:[], }, } }, mounted(){ this.initDomains() }, methods:{ initDomains(){ this.fromData.domains=[ { name: "小红", desc: "11123" }, { name: "小红", desc: "11123" } ] }, init(){ }, submit(formName){ this.$refs[formName].validate((valid) => { if (valid) { alert('submit!'); } else { console.log('error submit!!'); return false; } }); } } } </script>
补充知识:Vue+ElementUI 完整增删查改验证功能的表格
我就废话不多说了,大家还是直接看代码吧~
<template> <div class="block"> <el-col> <el-row> <el-form> <el-form-item> <el-input style="width: 250px;float: left" placeholder="请输入名称" v-model="query"></el-input> <el-button @click="handleSelect" style="float: left;margin-left: 10px">查询</el-button> <el-button @click="handleAdd" style="float: left;margin-left: 10px">新增</el-button> </el-form-item> </el-form> </el-row> <el-row> <el-table :data="tableData" style="width: 100%" border> <el-table-column prop="date" label="日期" width="250"> </el-table-column> <el-table-column prop="name" label="姓名" width="250"> </el-table-column> <el-table-column prop="address" label="地址" width="350"> </el-table-column> <el-table-column> <template slot-scope="scope"> <el-button size="mini" @click="handleEdit(scope.$index,scope.row)">编辑</el-button> <el-button size="mini" type="danger" @click="handleDelete(scope.$index,scope.row)">删除</el-button> </template> </el-table-column> </el-table> </el-row> <el-row> <el-dialog class="dialog" :title="operation===true " :visible.sync="dialogVisible" width="350px" > <el-form label-width="80px" :model="lineData" :rules="addRule" ref="lineData" > <el-form-item label="日期" prop="date"> <el-input v-model="lineData.date"></el-input> </el-form-item> <el-form-item label="姓名" prop="name"> <el-input v-model="lineData.name"></el-input> </el-form-item> <el-form-item label="地址"> <el-input v-model="lineData.address"></el-input> </el-form-item> <el-form-item> <el-button @click="handleSave" type="primary">确定</el-button> <el-button @click="handleCancel">取消</el-button> </el-form-item> </el-form> </el-dialog> </el-row> </el-col> </div> </template> <script>export default { data () { return { operation: true, dialogVisible: false, lineData: {}, editData: {}, query: '', addRule: { date: [{required: true, message: '请输入日期', trigger: 'blur'}], name: [{required: true, message: '请输入名称', trigger: 'blur'}] }, tableData: [{ id: 1, date: '2016-05-02', name: '王一虎', address: '上海市普陀区金沙江路 1518 弄' }, { id: 2, date: '2016-05-04', name: '王二虎', address: '上海市普陀区金沙江路 1517 弄' }, { id: 3, date: '2016-05-01', name: '王一虎', address: '上海市普陀区金沙江路 1519 弄' }, { id: 4, date: '2016-05-03', name: '王四虎', address: '上海市普陀区金沙江路 1516 弄' }] } }, methods: { handleEdit (index, row) { this.editData = JSON.stringify(row) this.lineData = JSON.parse(this.editData) this.dialogVisible = true this.operation = false }, handleDelete (index, row) { this.tableData.splice(index, 1) }, handleAdd () { this.dialogVisible = true this.operation = true this.lineData = {} this.lineData.id = Math.random() }, handleSelect () { if (this.query !== '') { const tmpData = [] for (let item of this.tableData) { if (item.name === this.query) { tmpData.push(item) } } this.tableData = tmpData } }, handleSave () { this.$refs.lineData.validate((valid) => { if (valid) { this.addLine(this.lineData) this.dialogVisible = false } else { alert('保存失败') return false } }) }, handleCancel () { this.dialogVisible = false }, addLine (item) { let existed = false for (let i = 0; i < this.tableData.length; i++) { if (this.tableData[i].id === item.id) { this.tableData[i].id = item.id this.tableData[i].name = item.name this.tableData[i].address = item.address this.tableData[i].date = item.date existed = true break } } if (!existed) { this.tableData.push(this.lineData) } } } } </script> <style scoped> .block{ width: 75%; margin-left: 400px; margin-top: 200px; } </style>
以上这篇使用element-ui +Vue 解决 table 里包含表单验证的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 中国武警男声合唱团《辉煌之声1天路》[DTS-WAV分轨]
- 紫薇《旧曲新韵》[320K/MP3][175.29MB]
- 紫薇《旧曲新韵》[FLAC/分轨][550.18MB]
- 周深《反深代词》[先听版][320K/MP3][72.71MB]
- 李佳薇.2024-会发光的【黑籁音乐】【FLAC分轨】
- 后弦.2012-很有爱【天浩盛世】【WAV+CUE】
- 林俊吉.2012-将你惜命命【美华】【WAV+CUE】
- 晓雅《分享》DTS-WAV
- 黑鸭子2008-飞歌[首版][WAV+CUE]
- 黄乙玲1989-水泼落地难收回[日本天龙版][WAV+CUE]
- 周深《反深代词》[先听版][FLAC/分轨][310.97MB]
- 姜育恒1984《什么时候·串起又散落》台湾复刻版[WAV+CUE][1G]
- 那英《如今》引进版[WAV+CUE][1G]
- 蔡幸娟.1991-真的让我爱你吗【飞碟】【WAV+CUE】
- 群星.2024-好团圆电视剧原声带【TME】【FLAC分轨】