vue-动态添加/删除输入框

2 篇文章 0 订阅

父组件helloWord.vue中

<template>
  <div class="content-body">
    <div>动态添加/删除</div>
    <div>
      <table border="1" cellpadding="0" cellspacing="0">
        <thead>
        <th v-for="(item,index) in dataArr" :key="item.guid" style="margin:10px 0">
          <button @click="deleteS(index)">删除</button>
          <n-input></n-input>
        </th>
        </thead>
        <tbody>
          <tr >
            <td v-for="(item) in dataArr" :key="item.guid" style="margin:10px 0">
              <v-input></v-input>
            </td>
          </tr>
        </tbody>
      </table>
    </div>
    <div>
      <button @click="addNew">添加</button>
    </div>
  </div>
</template>

<script>
  import Utils from '../utils/utils.js'
  import nInput from './nInput'
  import vInput from './vInput'
  export default {
    components:{
      nInput,
      vInput
    },
    data() {
      return {
        dataArr:[],
      }
    },
    methods: {
      // 添加
      addNew(){
        // 将生成的guid push至dataArr,guid是为了保证每个的唯一性,千万别用index作为key
        this.dataArr.push({guid:Utils.guid()});
        console.log(this.dataArr);
      },
      // 删除
      deleteS(index){
        // 删除指定下标
        this.dataArr.splice(index,1);
      }
    },
  }
</script>
<style scoped>

</style>

子组件nInput .vue

<template>
  <div>
    <span>标题</span>
    <input type="text" :value="inputN">
  </div>
</template>

<script>
  export default {
    name: "nInput",
    data() {
      return {
        inputN: '',
      }
    },
    methods: {
    }
  }
</script>

子组件vInput .vue

<template>
  <div>
    <span>内容</span>
    <input type="text" :value="inputV">
  </div>
</template>

<script>
  export default {
    name: "vInput",
    data() {
      return {
        inputV: '',
      }
    },
    methods: {
    }
  }
</script>

utils.js

const utils = {
  guid: function() {
    return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) {
      var r = Math.random() * 16 | 0,
        v = c == 'x' ? r : (r & 0x3 | 0x8);
      return v.toString(16);
    });
  }
}
export default utils

效果图
vue-动态添加/删除输入框

实例地址

原文地址

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值