Home > Web Front-end > JS Tutorial > body text

Learn how to dynamically add and delete vue-iview

coldplay.xixi
Release: 2020-08-08 16:27:29
forward
1814 people have browsed it

Learn how to dynamically add and delete vue-iview

The example in this article shares the specific code for dynamic addition and deletion of vue-iview for your reference. The specific content is as follows

Reference link: vue iview dynamic new Adding and deleting

I made tests and minor modifications based on the above blog, the effect is as follows:

The source code is as follows:

html code

<template>
 <Form ref="capsuleAttr" :model="capsuleAttr" :label-width="100" style="width: 80%">
  <ul>
  <li v-for="(item, index) in capsuleAttr.attrList" v-if="item.status" :key="index">
  <FormItem
   style="width:80%;"
   label="属性名称:"
   :prop="&#39;attrList.&#39; + index + &#39;.AttrName&#39;"
   :rules="{required: true, message: &#39;属性名称不能为空&#39;, trigger: &#39;blur&#39;}"
  >
   <Col span="7">
   <Input v-model.trim="item.AttrName" placeholder="属性名称" />
   </Col>
   <Col span="2" style="margin-left:20%;">
   <Button @click="handleRemove(item,index)" type="error" icon="md-close">删除</Button>
   </Col>
  </FormItem>
  <FormItem
   style="width:80%;"
   label="温度:"
   :prop="&#39;attrList.&#39; + index + &#39;.Temperature&#39;"
   :rules="{required: true, message: &#39;温度不能为空&#39;, trigger: &#39;blur&#39;,type:&#39;string&#39;, transform(val) {
  return String(val)}}"
  >
   <Input v-model.trim="item.Temperature" placeholder="温度" />
  </FormItem>
  <FormItem
   style="width:80%;"
   label="流量:"
   :prop="&#39;attrList.&#39; + index + &#39;.Volume&#39;"
   :rules="{required: true, message: &#39;流量不能为空&#39;, trigger: &#39;blur&#39;}"
  >
   <Input v-model.trim="item.Volume" placeholder="流量" />
  </FormItem>
  <FormItem label="推荐流量:" style="width:80%;">
   <Input v-model.trim="item.RcommendVolume" placeholder="流量" />
  </FormItem>
  <FormItem label="吹气时间:" style="width:80%;">
   <Input v-model.trim="item.Blow" placeholder="吹气时间" />
  </FormItem>
  <FormItem label="浸泡时间:" style="width:80%;">
   <Input v-model.trim="item.Soak" placeholder="浸泡时间" />
  </FormItem>

  <FormItem
   label="作业过程描述:"
   style="width:80%;"
   :prop="&#39;attrList.&#39; + index + &#39;.WorkDesc&#39;"
   :rules="{required: true, message: &#39;作业过程描述不能为空&#39;, trigger: &#39;blur&#39;}"
  >
   <Input
   v-model="item.WorkDesc"
   type="textarea"
   :autosize="{minRows: 5,maxRows: 10}"
   placeholder="输入作业过程描述..."
   />
  </FormItem>
  <FormItem style="width:80%;" label="作业顺序:">
   <!-- :rules="ruleWorkSort" -->
   <Input v-model.trim="item.WorkSort" placeholder="作业顺序" />
  </FormItem>
  <pider dashed />
  </li>
  </ul>

  <FormItem>
  <Row>
  <Col span="8">
   <Button type="dashed" long @click="handleAttrAdd" icon="md-add">增加属性</Button>
  </Col>
  </Row>
  </FormItem>
  <FormItem>
  <Button type="primary" @click="handleAttrSubmit(&#39;capsuleAttr&#39;)">保存</Button>
  <Button @click="$router.go( -1)" style="margin-left: 8px">返回</Button>
  </FormItem>
  </Form>
</template>
Copy after login

JS code

<script>
export default {
 data () {
 return {
 capsuleAttr: {
 // 胶囊属性
 index: 1,
 attrList: [
  {
  AttrName: &#39;&#39;,
  Temperature: &#39;&#39;,
  Volume: &#39;&#39;,
  CapsuleId: &#39;&#39;, // 属性ID
  RcommendVolume: &#39;&#39;, // 推荐流量
  WorkDesc: &#39;&#39;,
  Blow: &#39;&#39;, // 吹气时间
  Soak: &#39;&#39;, // 浸泡时间
  WorkSort: &#39;&#39;,
  index: 1,
  status: 1
  }
 ]
 }
 }
 },
 method: {
 // 添加属性
 handleAttrAdd () {
 this.capsuleAttr.index++
 this.capsuleAttr.attrList.push({
 AttrName: &#39;&#39;,
 Temperature: &#39;&#39;,
 Volume: &#39;&#39;,
 WorkDesc: &#39;&#39;,
 WorkSort: &#39;&#39;,
 RcommendVolume: &#39;&#39;, // 推荐流量
 Blow: &#39;&#39;, // 吹气时间
 Soak: &#39;&#39;, // 浸泡时间
 index: this.capsuleAttr.index,
 status: 1
 })
 },
 handleRemove (item, index) {
 console.log(item.Id)
 if (item.Id) {
 this.$Modal.confirm({
  title: &#39;删除本条记录&#39;,
  onOk: () => {
  ProductModule.getCapsuleAttributeDel(item.Id).then(res => {
  if (res.data.Success) {
  this.capsuleAttr.attrList[index].status = 0
  this.$Message.success(&#39;删除成功&#39;)
  }
  })
  },
  onCancel: () => {
  console.log(&#39;onCancel&#39;)
  }
 })
 return
 }
 this.capsuleAttr.attrList[index].status = 0
 },
 // 胶囊属性保存新增
 handleAttrSubmit (name) {
 this.$refs[name].validate(valid => {
 if (valid) {
  if (this.userId) {
  this.getCapsuleAttrEditAdd()
  } else {
  if (this.capsuleId) {
  this.getSaveAttrCreate()
  } else {
  this.$Message.error(&#39;请先保存胶囊数据&#39;)
  }
  }
 } else {
  this.$Message.error(&#39;保存失败!&#39;)
 }
 })
 }
 }

}
</script>
Copy after login

For tutorials on vue.js components, please click on the special vue.js component learning tutorial to learn.

Related learning recommendations: javascript tutorial

The above is the detailed content of Learn how to dynamically add and delete vue-iview. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
vue
source:jb51.net
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template