Tenga en cuenta los siguientes requisitos:
Requisito 1: Diseñe la página, prepare los datos iniciales (su propia estructura de datos escrita a mano)
Requisito 2: Cuando el cuadro de entrada no tenga valor, proporcione un mensaje al usuario y debe haber valores antes de agregar nuevos datos
Requisito 3: Agregar funciones: piense en una buena estructura de datos y clave de objeto unificado
Requisito 4: Haga clic en la función de edición y asigne el valor al cuadro de entrada (no opere el dom, la página basada en datos)
Requisito 5: Después de que el usuario haga modificaciones, haga clic en el mismo botón - para lograr el efecto de actualización de la página después de editar
el requisito 6: haga clic en Eliminar para eliminar esta fila de datos
<template>
<div id="app">
<div>
<span>姓名:</span>
<input type="text" v-model="name" />
</div>
<div>
<span>年龄:</span>
<input type="number" v-model.number="age" />
</div>
<div>
<span>性别:</span>
<select v-model="sex">
<option value="男">男</option>
<option value="女">女</option>
</select>
</div>
<div>
<button @click="addFn">添加/修改</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 arr" :key="obj.id">
<td>{
{
index + 1 }}</td>
<td>{
{
obj.name }}</td>
<td>{
{
obj.age }}</td>
<td>{
{
obj.gender }}</td>
<td>
<button @click="delFn(index)">删除</button>
<button @click="editFn(index)">编辑</button>
</td>
</tr>
</table>
</div>
</div>
</template>
<script>
export default {
data() {
return {
name: "",
age: 0,
sex: "",
arr: [
{
id: 1, name: "Tom", age: 19, gender: "男" },
{
id: 2, name: "Jone", age: 21, gender: "女" },
],
selectIndex: "",
flag: false,
};
},
methods: {
addFn() {
if (this.name.length === 0 || this.age.length === 0) {
alert("内容不能为空");
return;
}
// let id = this.arr.length > 0 ? this.arr[this.arr.length - 1].id + 1 : 1;
if (!this.flag) {
this.arr.push({
// id: id,
name: this.name,
age: this.age,
gender: this.sex,
});
} else {
this.arr.splice(this.selectIndex, 1, {
name: this.name,
age: this.age,
gender: this.sex,
});
this.flag = false;
}
this.name = "";
this.age = 0;
this.sex = "";
},
editFn(i) {
this.name = this.arr[i].name;
this.age = this.arr[i].age;
this.sex = this.arr[i].gender;
this.selectIndex = this.arr.findIndex((obj) => obj.id === i + 1);
this.flag = true;
},
delFn(ind) {
this.arr.splice(ind, 1);
},
},
};
</script>
El código anterior puede cumplir con los requisitos anteriores y la representación es la siguiente:
Nota: El código vue anterior se basa en un paquete de módulo global @vue/cli (obtenga el comando vue) proporcionado oficialmente por Vue, creando así un proyecto de andamio y utilizando la herramienta de empaquetado webpack. Tenga cuidado de descargar el paquete de terceros por completo cuando lo utilice.