• 1.铺设页面, 准备初始的数据并最终完整页面结构设计和渲染到页面上
<template>
  <div id="app">
    <div>
      <span>姓名:</span>
      <input type="text" />
    </div>
    <div>
      <span>年龄:</span>
      <input type="number" />
    </div>
    <div>
      <span>性别:</span>
      <select >
        <option value="男">男</option>
        <option value="女">女</option>
      </select>
    </div>
    <div>
      <button >添加/修改</button>
    </div>
    <div>
      <table
        border="1"
        cellpadding="10"
        cellspacing="0"
      >
        <tr>
          <th>序号</th>
          <th>姓名</th>
          <th>年龄</th>
          <th>性别</th>
          <th>操作</th>
        </tr>
        <tr v-for="(obj, index) in dataArr" :key="index">
          <td>{{index + 1}}</td>
          <td>{{obj.name}}</td>
          <td>{{obj.aeg}}</td>
          <td>{{obj.sex}}</td>
          <td>
            <button >删除</button>
            <button >编辑</button>
          </td>
        </tr>
      </table>
    </div>
  </div>
</template>
<script>
export default {
  data () {
    return {
      dataArr: [
        {
          name: 'zs',
          age: 18,
          sex: '男'
        },
        {
          name: 'Jone',
          age: 21,
          sex: '女'
        }
      ]
    }
  }
}
</script>

  • 2.利用 v-model 实现输入框数据的双向绑定,并在 data 里赋初值
 <input type="text" v-model.trim="username" />
 <input type="number" v-model.number="userage" />
data () {
    return {
      username: '',
      userage: 0,
      gender: ''
    }
  }

  • 3.实现添加功能 - 给 “添加/修改” 按钮绑定点击事件,当在输入框里填写完数据后点击 “添加/修改” 按钮后实现将数据添加到下面的表格里即将数据添加到 data 里面的 dataArr数组 里
<button @click="addOrEditFn">添加/修改</button>
  methods: {
    // 添加/修改 点击事件的方法
    addOrEditFn () {
      let newObj = {
        name: this.username,
        age: this.userage,
        sex: this.gender
      }
      this.dataArr.push(newObj)
    }
  }

 

4.实现删除功能-- 给 “删除” 按钮绑定点击事件,并将当前的索引 index 当做参数传递给点击事件,当点击 “删除” 按钮后,将数据从表格里删除;当表格里的数据都被删除了时,利用 v-show/v-if 将表格隐藏起来

<button @click="del(index)">删除</button>
      <table
        border="1"
        cellpadding="10"
        cellspacing="0"
        v-show="dataArr.length > 0"
      >
    // 实现删除功能
    del(index) {
      this.dataArr.splice(index,1)
    }

 

 

  • 5.点击“编辑”按钮时,将对应的数据信息显示到输入框的对应处,也就是当点击“编辑”按钮时应该将对应的数据里的三个值(姓名、年龄、性别)赋值给输入框里对应处,这里还是利用 index 作为索引传参给点击事件
<button @click="edit(index)">编辑</button>
    // 实现编辑功能
    edit(index) {
      // 取出要编辑的对象信息
      const editObj = this.dataArr[index]
      this.username = editObj.name
      this.userage = editObj.age
      this.gender = editObj.sex
    }

 

  • 6.当用户点击“编辑”按钮后,对应的数据显示在输入框里,当用户修改完输入框里的数据后,再次点击“添加/修改”按钮时,应该实现将表格下面对应的数据进行修改,而不是添加
  • 我们可以在data里声明一个变量(editIndex)专门用来保存正在编辑的对象的索引,并在编辑的函数里进行保存当前的索引值
  • 此时当修改好输入框里的信息再次点击“添加/修改”按钮时如果 this.editIndex 的值不为空,那么代表本次是要编辑更新 this.dataArr 数组里面当前正在编辑的下标(this.editIndex),然后将新的对象替换进去(newObj)【更新完成后需要将 this.editIndex 赋值为 null 以保证下次点击是新增效果】,反之就是新增
  • 这样功能就实现完啦
editIndex: null, // 保存正在编辑的对象的索引,注意这里的初始值不能为0及0以上的数
    edit(index) {
      this.editIndex = index // 保存当前的索引值
    }
   // 添加/修改 点击事件的方法
    addOrEditFn () {
      let newObj = {
        name: this.username,
        age: this.userage,
        sex: this.gender
      }
      
      if (this.editIndex !== null) {
        this.$set(this.dataArr, this.editIndex, newObj)

        this.editIndex = null // 更新后,保证下次点击是新增效果
      } else { // 新增
        this.dataArr.push(newObj)
      }
    },

 

7.这里我们不难发现在点击“添加/修改”按钮时,我们还专门为此准备了一个新对象,newObj,那么其实我们可以让 data 里的 username、userage、gender直接和 dataArr里面的 key相等,这里我们可以利用解构赋值和浅拷贝,同理对 edit (index) 方法里的 this.username、this.userage、this.gender 也可以用浅拷贝实现优化

最终代码如下:

<template>
  <div id="app">
    <div>
      <span>姓名:</span>
      <input type="text"
             v-model.trim="newObj.name" />
    </div>
    <div>
      <span>年龄:</span>
      <input type="number"
             v-model.number="newObj.age" />
    </div>
    <div>
      <span>性别:</span>
      <select v-model="newObj.sex">
        <option value="男">男</option>
        <option value="女">女</option>
      </select>
    </div>
    <div>
      <button @click="addOrEditFn">添加/修改</button>
    </div>
    <div>
      <table border="1"
             cellpadding="10"
             cellspacing="0"
             v-show="dataArr.length > 0">
        <tr>
          <th>序号</th>
          <th>姓名</th>
          <th>年龄</th>
          <th>性别</th>
          <th>操作</th>
        </tr>
        <tr v-for="(obj, index) in dataArr"
            :key="index">
          <td>{{index + 1}}</td>
          <td>{{obj.name}}</td>
          <td>{{obj.aeg}}</td>
          <td>{{obj.sex}}</td>
          <td>
            <button @click="del(index)">删除</button>
            <button @click="edit(index)">编辑</button>
          </td>
        </tr>
      </table>
    </div>
  </div>
</template>
<script>
export default {
  data () {
    return {
      // username: '',
      // userage: 0,
      // gender: '',
      newObj: {
        name: '',
        age: 0,
        sex: ''
        },
      editIndex: null, // 保存正在编辑的对象的索引,注意这里的初始值不能为0及0以上的数
      dataArr: [
        {
          name: 'zs',
          age: 18,
          sex: '男'
        },
        {
          name: 'Jone',
          age: 21,
          sex: '女'
        }
      ]
    }
  },
  methods: {
    // 添加/修改 点击事件的方法
    addOrEditFn () {
      // 注意:对象是引用关系,所以必须让数组里的对象和newObj脱离引用关系,因为这里只有一层,于是我们可以利用浅拷贝实现
      let theObj = {...this.newObj}
      // let newObj = {
      //   name: this.username,
      //   age: this.userage,
      //   sex: this.gender
      // }

      if (this.editIndex !== null) {
        this.$set(this.dataArr, this.editIndex, theObj)

        this.editIndex = null // 更新后,保证下次点击是新增效果
      } else { // 新增
        this.dataArr.push(theObj)
      }
    },
    // 实现删除功能
    del (index) {
      this.dataArr.splice(index, 1)
    },
    // 实现编辑功能
    edit (index) {
      // 取出要编辑的对象信息
      const editObj = this.dataArr[index]
      // this.username = editObj.name
      // this.userage = editObj.age
      // this.gender = editObj.sex
      //优化
      this.newObj = {...editObj}

      this.editIndex = index // 保存当前的索引值
    }
  }
}
</script>

Logo

前往低代码交流专区

更多推荐