vue--实现学生信息管理案例
1.铺设页面, 准备初始的数据并最终完整页面结构设计和渲染到页面上<template><div id="app"><div><span>姓名:</span><input type="text" /></div><div><span>年龄:</span><input type
·
- 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>
更多推荐
已为社区贡献8条内容
所有评论(0)