本地json数据的增删改查#Vue3

本文详细展示了如何在Vue3项目中使用Element-Plus和Pinia库实现对本地json数据的增删改查功能,包括搜索、表格展示、表单编辑和CRUD操作的实现代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本地json数据的增删改查#Vue3

实现效果:

增删改查

在这里插入图片描述
test.vue文件源代码

<!-- test.vue -->
<template>
  <!-- 演示地址 -->
  <div class="dem-add">
    <!-- Search start -->
    <div class="dem-title">
      <p>演示地址</p>
      <el-input
        class="query-input"
        v-model="tableForm.name"
        placeholder="请输入姓名搜索"
      />
      <el-button type="primary" @click="handleQueryName">搜索</el-button>
      <el-button type="primary" @click="handleAdd">增加</el-button>
    </div>
    <!-- Search end -->
    <!-- Table start -->
    <div class="bs-page-table">
      <el-table
        :data="tableData"
        style="width: 100%"
        border
        ref="multipleTableRef"
      >
        <el-table-column prop="name" label="演示端" width="150" />
        <el-table-column prop="address" label="地址" width="300" />
        <el-table-column prop="state" label="特殊说明" width="120" />
        <el-table-column prop="plus" label="附加" width="120" />
        <el-table-column fixed="right" label="Operations" width="120">
          <template #default="scope">
            <el-button
              link
              type="primary"
              size="small"
              @click="handleRowDel(scope.row)"
              style="color: #f56c6c"
            >
              删除
            </el-button>
            <el-button
              link
              type="primary"
              size="small"
              @click="handleEdit(scope.row)"
              >编辑</el-button
            >
          </template>
        </el-table-column>
      </el-table>
      <el-dialog
        v-model="dialogFormVisible"
        :title="dialogType.name === 'add' ? '新增' : '编辑'"
        width="500"
      >
        <el-form :model="tableForm">
          <el-form-item label="演示端" :label-width="80">
            <el-input v-model="tableForm.name" autocomplete="off" />
          </el-form-item>
          <el-form-item label="地址" :label-width="80">
            <el-input v-model="tableForm.address" autocomplete="off" />
          </el-form-item>
          <el-form-item label="特殊说明" :label-width="80">
            <el-input v-model="tableForm.state" autocomplete="off" />
          </el-form-item>
          <el-form-item label="附加" :label-width="80">
            <el-input v-model="tableForm.plus" autocomplete="off" />
          </el-form-item>
        </el-form>
        <template #footer>
          <div class="dialog-footer">
            <el-button type="primary" @click="dialogConfirm"> 确认 </el-button>
          </div>
        </template>
      </el-dialog>
    </div>
    <!-- Table end -->
  </div>
</template>

<script lang="ts" setup >
import { reactive, ref, onMounted } from "vue";
import { get, post, del, put } from "/vue/inforce4/src/utils/request";

// 演示地址
// 默认对话框关闭状态
const dialogFormVisible = ref(false);
const tableForm = ref({
  name: "Tom3",
  address: "浙江省",
  state: "在职",
  plus: "12133313133",
});
// 定义对话框标题
const dialogType = ref({ name: "add" });
// 定义表单变量
let tableData = ref([]);
// 调用json数据在表单显示
async function port() {
  const res = await get("/api/demdata");
  tableData.value = res.data;
}
onMounted(() => {
  port();
});
// 搜索(通过name值查找)
const handleQueryName = async () => {
  const res = await get("/api/demdata");
  const result = res.data.filter(
    (item: any) => item.name === tableForm.value.name
  );
  // 将找到的数据返回给表单显示
  tableData.value = result;
};
// 新增
const handleAdd = async () => {
  // 打开新增对话框
  dialogFormVisible.value = true;
  dialogType.value.name = "add";
};
// 删除一条数据
const handleRowDel = async (y: any) => {
  // 找到要删除的json数据中对应的对象
  await del(`/api/demdata/${y.id}`);
  // 将表单中的该数据也删除
  tableData.value.splice(y, 1);
  // 重新从json中读取数据并返回给表单显示
  port();
};
// 编辑
const handleEdit = (row: any) => {
  // 打开编辑对话框
  dialogFormVisible.value = true;
  dialogType.value.name = "edit";
  // 将对话框中的数据返回给表单
  tableForm.value = { ...row };
};
// 确认
const dialogConfirm = async () => {
  // 判断是新增还是编辑
  if (dialogType.value.name === "add") {
    // 先把数据添加给json数据,JSON.stringify()将对象转化为数组
    await post("/api/demdata", JSON.stringify(tableForm.value));
    // 然后再关闭对话框
    dialogFormVisible.value = false;
    // 最后再返回给表单重新显示
    port();
  } else {
    await put(
      `/api/demdata/${tableForm.value.id}`,
      JSON.stringify(tableForm.value)
    );
    dialogFormVisible.value = false;
    port();
  }
};
</script>

<style scoped lang="scss">
p {
  color: #000;
  font-size: 20px;
}
// 演示地址
.dem-add {
  width: 800px;
  margin: 20px 600px;
  // 标签
  .dem-title {
    display: flex;
    p {
      float: left;
      width: 100px;
    }
    // 搜索框
    .query-input {
      width: 200px;
      margin-left: 400px;
      margin-top: 10px;
      height: 34px;
    }
    // 增加按钮
    .el-button {
      float: left;
      margin: 10px 10px;
    }
  }
  // 表格
  .bs-page-table {
    .el-table {
      border: 1px solid rgb(219, 219, 219);
    }
  }
}

</style>

json数据

{
"demdata": [
    {
      "id": "3",
      "name": "Tom1",
      "address": "浙江省",
      "state": "在职",
      "plus": "12133313133"
    },
    {
      "id": "520d",
      "name": "Tom2",
      "address": "浙江省",
      "state": "在职",
      "plus": "12133313133"
    },
    {
      "id": "ca3e",
      "name": "Tom3",
      "address": "浙江省",
      "state": "在职",
      "plus": "12133313133"
    },
    {
      "id": "1",
      "name": "Tom4",
      "address": "浙江省",
      "state": "在职",
      "plus": "12133313133"
    },
    {
      "id": "4eff",
      "name": "Tom5",
      "address": "陕西省",
      "state": "离职",
      "plus": "12133313133"
    }
  ]
 }

项目的相关配置详见Vue3 + Vite + TS + Element-Plus + Pinia 项目准备(json-server模拟数据接口)#喂吃版

### 如何在 Vue 3 中使用 Axios 实现 CRUD 操作 为了展示如何利用 Vue 3 和 Axios 来完成基本的增删改查 (CRUD) 功能,下面提供了详细的说明和相应的代码片段。 #### 创建 Vue 3 项目并配置 Axios 首先,在本地环境中准备好必要的开发环境之后,可以创建一个新的 Vue 3 应用程序,并安装 Axios: ```bash vue create axios-vue3-demo cd axios-vue3-demo npm install axios ``` 接着,在项目的入口文件 `main.js` 或者其他合适的位置引入 Axios 并设置基础 URL: ```javascript import { createApp } from &#39;vue&#39; import App from &#39;./App.vue&#39; // 导入axios库 import axios from "axios"; const app = createApp(App) // 配置全局默认的基础URL, 方便后续调用API接口 axios.defaults.baseURL = &#39;https://jsonplaceholder.typicode.com&#39;; app.config.globalProperties.$http = axios; app.mount(&#39;#app&#39;) ``` #### 设计组件结构 假设有一个简单的待办事项列表应用程序作为例子。该应用允许用户查看、添加、编辑和删除条目。为此目的设计如下所示的主要组件布局: - **TodoList**: 显示所有待办事项。 - **AddItemForm**: 提供表单让用户输入新的待办项。 - **EditItemDialog**: 当点击某个特定待办项时弹出对话框以便修改其内容。 #### 编写 TodoList 组件中的读取逻辑 在 `components/TodoList.vue` 文件内定义一个方法来获取远程 API 上的数据源,并将其存储在一个响应式变量中以驱动视图更新: ```html <template> <ul v-if="todos.length"> <li v-for="(todo, index) in todos" :key="index">{{ todo.title }}</li> </ul> </template> <script> export default { data() { return { todos: [] } }, created() { this.fetchTodos() }, methods: { async fetchTodos() { try { const response = await this.$http.get(&#39;/todos&#39;); this.todos = response.data.slice(0, 10); // 只加载前十个记录简化示例 } catch (error) { console.error(&#39;There was an error fetching the todos!&#39;, error); } } } } </script> ``` 此部分实现了从服务器拉取消息的功能[^2]。 #### 添加新待办项(Create) 对于新增加的操作,则可以在 `components/AddItemForm.vue` 内编写提交处理函数,当用户填写完毕后触发 POST 请求向服务端推送数据: ```html <template> <form @submit.prevent="handleSubmit"> <input type="text" placeholder="Enter a new item..." required /> <button>Add Item</button> </form> </template> <script> export default { name: &#39;AddItemForm&#39;, props: [&#39;onSubmit&#39;], methods: { handleSubmit(event) { let title = event.target.elements[0].value.trim(); if (!title) return; this.onSubmit({ title }).then(() => { event.target.reset(); // 清除表单项 }); } } }; </script> ``` 父级组件可以通过传递回调的方式来接收子组件发出的新对象实例化请求,并执行保存动作。 #### 更新现有待办项(Update) 针对已存在的某一条记录做更改的话,通常会采用模态窗口的形式呈现给用户进行交互;这里简单起见只给出核心思路——即通过 PUT 方法把变更后的 JSON 发送回去覆盖旧版本: ```html <!-- components/EditItemDialog.vue --> <template> <!-- ...省略HTML模板... --> </template> <script> export default { props: ["item"], emits: ["update:item"], methods: { handleSave(updatedData) { this.$emit("update:item", updatedData); // 假设我们已经有了要更新的对象id和其他属性... this.$http.put(`/todos/${this.item.id}`, updatedData).then(response => { alert(`Updated successfully!`); }) } } }; </script> ``` 上述代码段展示了怎样监听来自用户的确认事件并将变化同步回数据库。 #### 删除指定待办项(Delete) 最后就是移除操作了,这一步骤相对较为直接:只需确定目标 ID 后发起 DELETE 请求即可达成目的: ```javascript methods: { removeTodo(id){ this.$http.delete(`/todos/${id}`).then((response)=>{ // 成功后刷新当前显示的内容 this.fetchTodos(); }).catch(error=>{ console.log(error.message); }); } } ``` 综上所述,以上便是完整的 Vue 3 结合 Axios 执行 CRUD 流程的方法介绍。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值