亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue3實現(xiàn)Element Plus表格的多選功能與條件操作

 更新時間:2024年08月09日 09:15:13   作者:碼農(nóng)研究僧  
Element-plus是ElementUI的升級版,是一套基于vue2與vue3的桌面端組件庫,它提供了豐富的組件幫助開發(fā)人員快速構建功能強大、風格統(tǒng)一的頁面,本文給大家介紹了Vue3實現(xiàn)Element Plus表格的多選功能與條件操作,需要的朋友可以參考下

前言

本文主要以Demo的形式展示,展示要點為主

基本知識點

  1. 數(shù)據(jù)綁定
    v-model 用于雙向綁定數(shù)據(jù),el-table 的 :data 屬性用于綁定表格數(shù)據(jù)

  2. 選擇框列
    使用 el-table-column 的 type=“selection” 屬性來創(chuàng)建多選框列

  3. 處理選擇變化
    @selection-change 事件用于處理選擇狀態(tài)變化,獲取選中的數(shù)據(jù)

  4. 過濾和操作
    通過對選中的數(shù)據(jù)進行過濾和處理,實現(xiàn)不同的操作需求

1. Demo

多選按鈕通常用于選擇表格中的多行數(shù)據(jù)

常用的 UI 框架如 Element Plus 提供了易于集成的多選功能

<template>
  <el-table
    v-loading="loading"
    :data="tableData"
    :stripe="true"
    :show-overflow-tooltip="true"
    @selection-change="handleSelectionChange"
  >
    <el-table-column type="selection" width="55" />
    <el-table-column label="名稱" prop="name" />
    <el-table-column label="狀態(tài)" prop="status" />
    <el-table-column label="操作" fixed="right" width="200">
      <template #default="scope">
        <el-button @click="viewDetails(scope.row)">查看詳情</el-button>
      </template>
    </el-table-column>
  </el-table>
  <el-button @click="handleBatchAction">執(zhí)行批量操作</el-button>
</template>

其js如下:

<script setup>
import { ref } from 'vue';
import { ElTable, ElTableColumn, ElButton, ElMessage } from 'element-plus';

const loading = ref(false);
const tableData = ref([
  { id: 1, name: 'Item 1', status: '未提交' },
  { id: 2, name: 'Item 2', status: '已提交' },
  // ...更多數(shù)據(jù)
]);

const selectedRows = ref([]);

const handleSelectionChange = (selection) => {
  selectedRows.value = selection;
};

const viewDetails = (row) => {
  // 顯示詳情
  console.log('查看詳情:', row);
};

const handleBatchAction = () => {
  if (selectedRows.value.length === 0) {
    ElMessage.warning('請選擇要操作的項');
    return;
  }

  if (selectedRows.value.some(row => row.status !== '未提交')) {
    ElMessage.warning('只能對“未提交”狀態(tài)的記錄進行操作');
    return;
  }

  // 執(zhí)行批量操作
  console.log('批量操作:', selectedRows.value);
};
</script>
  • 表格組件:el-table 組件用于展示數(shù)據(jù),type=“selection” 創(chuàng)建多選框列
  • handleSelectionChange:處理選中項的變化,將選中的數(shù)據(jù)存儲在 selectedRows 中
  • viewDetails:用于查看單條記錄的詳細信息
  • handleBatchAction:處理批量操作的邏輯,包括檢查選中項的狀態(tài)是否符合條件(如狀態(tài)為“未提交”),然后執(zhí)行操作

2. 實戰(zhàn)

以上主要為了展示Demo的基本要點

對于實戰(zhàn)也同理

增加選項按鈕以及按鈕觸發(fā)

通過按鈕的選中收集相關信息

將列表的id以數(shù)組的形式傳輸給后端
(上面我多收集了一個status,不滿足的status可以在此處做過濾,讓其不會觸發(fā)按鈕框并且有提示)

結(jié)果如下:

基于上述的Demo以及實戰(zhàn)

通過按鈕做一鍵刪除 、修改等操作就很簡單了

以上就是Vue3實現(xiàn)Element Plus表格的多選功能與條件操作的詳細內(nèi)容,更多關于Vue3 Element Plus表格多選與操作的資料請關注腳本之家其它相關文章!

相關文章

  • vue項目配置使用flow類型檢查的步驟

    vue項目配置使用flow類型檢查的步驟

    這篇文章主要介紹了vue項目配置使用flow類型檢查的步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • vue實現(xiàn)顯示消息提示框功能

    vue實現(xiàn)顯示消息提示框功能

    這篇文章主要介紹了vue實現(xiàn)顯示消息提示框功能,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • vue.js實現(xiàn)雙擊放大預覽功能

    vue.js實現(xiàn)雙擊放大預覽功能

    這篇文章主要為大家詳細介紹了vue.js實現(xiàn)雙擊放大預覽功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-06-06
  • 創(chuàng)建nuxt.js項目流程圖解

    創(chuàng)建nuxt.js項目流程圖解

    Nuxt.js是創(chuàng)建Universal Vue.js應用程序的框架。它的主要范圍是UI渲染,同時抽象出客戶端/服務器分布。我們的目標是創(chuàng)建一個足夠靈活的框架,以便您可以將其用作主項目庫或基于Node.js的當前項目。
    2020-03-03
  • vue項目ElementUI組件中el-upload組件與圖片裁剪功能組件結(jié)合使用詳解

    vue項目ElementUI組件中el-upload組件與圖片裁剪功能組件結(jié)合使用詳解

    這篇文章主要介紹了vue項目ElementUI組件中el-upload組件與圖片裁剪功能組件結(jié)合使用,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Vue解決ajax跨域的問題

    Vue解決ajax跨域的問題

    這篇文章主要介紹了Vue解決ajax跨域的問題,跨域請求:是指協(xié)議名、主機名、端口號三者有任何一個不一樣,而且跨域請求是請求發(fā)出去了,服務器接收并返回了結(jié)果,只是瀏覽器沒有接收響應結(jié)果。感興趣的同學可以參考閱讀
    2023-04-04
  • vue項目fetch本地PAG格式文件404 NotFound的解決

    vue項目fetch本地PAG格式文件404 NotFound的解決

    這篇文章主要介紹了vue項目fetch本地PAG格式文件404 NotFound的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue Mixins混入介紹與使用

    Vue Mixins混入介紹與使用

    如果我們在每個組件中去重復定義這些屬性和方法會使得項目出現(xiàn)代碼冗余并提高了維護難度,針對這種情況官方提供了Mixins特性,這時使用Vue mixins混入有很大好處,下面就介紹下Vue mixins混入使用方法,需要的朋友參考下吧
    2023-02-02
  • vue3在setup中使用mapState解讀

    vue3在setup中使用mapState解讀

    這篇文章主要介紹了vue3在setup中使用mapState方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Vue實現(xiàn)獲取剪切板內(nèi)容的兩種方法

    Vue實現(xiàn)獲取剪切板內(nèi)容的兩種方法

    這篇文章主要為大家詳細介紹了Vue實現(xiàn)獲取剪切板內(nèi)容的兩種方法,文中的示例代碼講解詳細,具有一定的借鑒價值,有需要的小伙伴可以了解下
    2025-02-02

最新評論