首頁 >web前端 >js教程 >學習vue-iview動態新增和刪除的方法

學習vue-iview動態新增和刪除的方法

coldplay.xixi
coldplay.xixi轉載
2020-08-08 16:27:291848瀏覽

學習vue-iview動態新增和刪除的方法

本文實例為大家分享了vue-iview動態新增和刪除的具體程式碼,供大家參考,具體內容如下

參考連結:vue iview動態新增和刪除

我根據上面的部落格進行了test和小修改,效果如下:

源碼如下:

html程式碼

<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>

JS程式碼

<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>

關於vue.js元件的教程,請大家點選專題vue.js元件學習教程進行學習。

相關學習推薦:javascript教學

#

以上是學習vue-iview動態新增和刪除的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:jb51.net。如有侵權,請聯絡admin@php.cn刪除