欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue 3 + Element Plus 封裝單列控制編輯的可編輯表格組件的方法

 更新時間:2024年09月11日 11:22:45   作者:前端學(xué)步  
在Web應(yīng)用開發(fā)中實現(xiàn)表格數(shù)據(jù)編輯功能至關(guān)重要,本文將詳細(xì)介紹如何使用Vue3和ElementPlus庫來構(gòu)建一個支持單列編輯的表格組件,本教程詳細(xì)闡述了組件創(chuàng)建過程和數(shù)據(jù)綁定機(jī)制,幫助你快速掌握Vue3中表格編輯功能的實現(xiàn),感興趣的朋友一起看看吧

在Web應(yīng)用開發(fā)中,經(jīng)常需要提供表格數(shù)據(jù)的編輯功能。本文將介紹如何使用Vue 3結(jié)合Element Plus庫來實現(xiàn)一個支持單列控制編輯功能的表格,并通過封裝組件的形式提高代碼的復(fù)用性。通過本教程,你將學(xué)會如何構(gòu)建一個具備單列控制編輯功能的表格組件,并在表單提交時保存更改。

目標(biāo)

  • 實現(xiàn)一個基本的表格,其中包含日期、名稱和描述等列。
  • 表格中的每一項都可以在點擊編輯圖標(biāo)后進(jìn)入編輯模式。
  • 編輯模式下可以修改表格單元格的內(nèi)容。
  • 編輯完成后,可以通過失去焦點的方式提交更改。
  • 支持單列控制編輯,即可以單獨控制每一列表格單元格的編輯狀態(tài)。
  • 封裝成可復(fù)用的組件,便于在其他項目中使用。

創(chuàng)建表格組件

我們將創(chuàng)建一個主組件App.vue和一個子組件EditableCell.vue來實現(xiàn)表格的編輯功能。

主組件 App.vue

<template>
    <div class="table-layout">
      <el-table :data="tableData">
        <el-table-column type="index" label="序號" width="60" />
        <el-table-column prop="id" label="ID" width="80" />
        <el-table-column prop="date" label="日期">
          <template #default="scope">
            <EditableCell
              :cell-data="scope.row.date"
              :is-editing="scope.row.isEditDate"
              :column="scope.column.property"
              :row="scope.row"
              @toggleEdit="toggleEdit"
              @applyChanges="applyChanges"
            />
          </template>
        </el-table-column>
        <el-table-column prop="name" label="名稱">
          <template #default="scope">
            <EditableCell
              :cell-data="scope.row.name"
              :is-editing="scope.row.isEditName"
              :column="scope.column.property"
              :row="scope.row"
              @toggleEdit="toggleEdit"
              @applyChanges="applyChanges"
            />
          </template>
        </el-table-column>
        <el-table-column prop="description" label="描述">
          <template #default="scope">
            <EditableCell
              :cell-data="scope.row.description"
              :is-editing="scope.row.isEditDescription"
              :column="scope.column.property"
              :row="scope.row"
              @toggleEdit="toggleEdit"
              @applyChanges="applyChanges"
            />
          </template>
        </el-table-column>
      </el-table>
    </div>
  </template>
  <script setup>
  import { ref } from 'vue';
  import EditableCell from './EditableCell.vue'; // 確保路徑正確
  import { ElTable, ElTableColumn, ElInput, ElIcon } from 'element-plus';
  import { Edit } from '@element-plus/icons-vue';
  // 優(yōu)化后的tableData
  const tableData = ref([
    {
      id: 1,
      date: '2024-08-01',
      name: '項目A',
      description: '這是一個關(guān)于項目A的描述',
      isEditDate: false,
      isEditName: false,
      isEditDescription: false
    },
    {
      id: 2,
      date: '2024-08-15',
      name: '項目B',
      description: '這是一個關(guān)于項目B的描述',
      isEditDate: false,
      isEditName: false,
      isEditDescription: false
    },
    {
      id: 3,
      date: '2024-09-01',
      name: '項目C',
      description: '這是一個關(guān)于項目C的描述',
      isEditDate: false,
      isEditName: false,
      isEditDescription: false
    }
  ]);
  function toggleEdit(column, row) {
    if (column && row) {
      const editKey = `isEdit${column.charAt(0).toUpperCase() + column.slice(1)}`;
      row[editKey] = !row[editKey];
    }
  }
  function applyChanges(newValue, column, row) {
    if (column && row) {
      row[column] = newValue;
      const editKey = `isEdit${column.charAt(0).toUpperCase() + column.slice(1)}`;
      row[editKey] = false;
    }
  }
  </script>
  <style scoped>
  .table-layout {
    width: 60%;
    margin: 60px auto;
  }
  .edit-icon {
    margin: 10px 0 0 10px;
  }
  </style>

子組件 EditableCell.vue

<template>
  <div>
    <span v-if="!isEditing">{{ displayData }}</span>
    <el-input
      v-else
      v-model="displayData"
      style="width: 120px;"
      @blur="onBlur"
    />
    <el-icon color="#409EFF" class="edit-icon" @click="onToggleEdit">
      <Edit />
    </el-icon>
  </div>
</template>
<script>
export default {
  name: 'EditableCell',
 props: ['cellData', 'isEditing', 'column', 'row'], // 添加row屬性
  emits: ['toggleEdit', 'applyChanges'],
  data() {
    return {
      displayData: this.cellData
    };
  },
  watch: {
    cellData(newVal) {
      this.displayData = newVal;
    }
  },
  methods: {
    onToggleEdit() {
      this.$emit('toggleEdit', this.column, this.row); // 傳遞column和row
    },
    onBlur() {
      this.$emit('applyChanges', this.displayData, this.column, this.row); // 傳遞column和row
    }
  }
}
</script>
<style scoped>
.edit-icon {
  margin: 10px 0 0 10px;
}
</style>

說明

子組件 (EditableCell.vue):

  • 使用內(nèi)部狀態(tài)displayData來存儲編輯時的值,并通過watch確保它與cellData同步。
  • 在模板中,根據(jù)編輯狀態(tài)顯示不同的內(nèi)容。
  • onBlur方法中提交更改,并正確調(diào)用applyChanges方法。

父組件 (App.vue):

  • 在模板中,通過scope.column.property獲取列的屬性名稱,并將其傳遞給子組件。
  • 在模板中,通過scope.row將行數(shù)據(jù)傳遞給子組件。
  • toggleEdit方法中,通過構(gòu)造的editKey來切換編輯狀態(tài)。
  • applyChanges方法中,通過構(gòu)造的editKey來更新編輯狀態(tài),并保存新值。

通過這種方式,我們實現(xiàn)了表格的編輯功能,并確保了編輯狀態(tài)下數(shù)據(jù)的正確提交。

總結(jié)

本文介紹了如何使用Vue 3和Element Plus實現(xiàn)一個帶有編輯功能的表格。通過本文的步驟,你可以輕松地在自己的項目中實現(xiàn)類似的表格編輯功能。希望這篇教程對你有所幫助!

到此這篇關(guān)于Vue 3 + Element Plus 封裝單列控制編輯的可編輯表格組件的文章就介紹到這了,更多相關(guān)Vue 3 Element Plus 編輯表格組件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue3實現(xiàn)動態(tài)路由與手動導(dǎo)航

    Vue3實現(xiàn)動態(tài)路由與手動導(dǎo)航

    這篇文章主要為大家詳細(xì)介紹了如何在?Vue?3?中實現(xiàn)動態(tài)路由注冊和手動導(dǎo)航,確保用戶訪問的頁面與權(quán)限對應(yīng),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-12-12
  • vue中axios的封裝問題(簡易版攔截,get,post)

    vue中axios的封裝問題(簡易版攔截,get,post)

    這篇文章主要介紹了vue中axios的封裝問題(簡易版攔截,get,post),需要的朋友可以參考下
    2018-06-06
  • Vue使用echarts繪制柱狀圖和折線圖

    Vue使用echarts繪制柱狀圖和折線圖

    這篇文章主要為大家學(xué)習(xí)介紹了Vue如何使用echarts繪制柱狀圖和折線圖,文中有詳細(xì)的示例代碼,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-08-08
  • element表格el-table實現(xiàn)虛擬滾動解決卡頓問題

    element表格el-table實現(xiàn)虛擬滾動解決卡頓問題

    當(dāng)頁面數(shù)據(jù)過多,前端渲染大量的DOM時,會造成頁面卡死問題,本文主要介紹了element表格el-table實現(xiàn)虛擬滾動解決卡頓問題,具有一定的參考價值,感興趣的可以了解一下
    2023-10-10
  • 在Vue項目中使用d3.js的實例代碼

    在Vue項目中使用d3.js的實例代碼

    這篇文章主要介紹了在Vue項目中使用d3.js的實例代碼,非常不錯,具有參考借鑒價值價值,需要的朋友可以參考下
    2018-05-05
  • vue-router跳轉(zhuǎn)頁面的方法

    vue-router跳轉(zhuǎn)頁面的方法

    本篇文章主要介紹了vue-router跳轉(zhuǎn)頁面的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-02-02
  • 詳解Vue路由傳參的兩種方式query和params

    詳解Vue路由傳參的兩種方式query和params

    這篇文章主要介紹了Vue路由傳參的兩種方式query和params,介紹了query和params區(qū)別與總結(jié),結(jié)合示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • vue.js基于ElementUI封裝了CRUD的彈框組件

    vue.js基于ElementUI封裝了CRUD的彈框組件

    這篇文章主要介紹了vue.js基于ElementUI封裝了CRUD的彈框組件,問咋會給你圍繞主題展開詳細(xì)的內(nèi)容介紹,感興趣的小伙伴可以參考一下
    2022-07-07
  • vue項目怎樣用nginx反向代理WebSocket請求地址

    vue項目怎樣用nginx反向代理WebSocket請求地址

    這篇文章主要介紹了vue項目怎樣用nginx反向代理WebSocket請求地址問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • vuex的簡單使用教程

    vuex的簡單使用教程

    vuex是一個專門為vue.js設(shè)計的集中式狀態(tài)管理架構(gòu)。這篇文章主要介紹了vuex的簡單使用,需要的朋友可以參考下
    2018-02-02

最新評論