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

Vue3 + Element Plus Transfer 穿梭框自定義分組的示例詳解

 更新時間:2025年07月03日 10:30:33   作者:滿  
本文介紹Vue3結合ElementPlus實現(xiàn)Transfer穿梭框自定義分組的四種方法,每種方法結合實例代碼給大家介紹的非常詳細,感興趣的朋友一起看看吧

1. 使用render-content自定義渲染

<template>
  <el-transfer
    v-model="selectedData"
    :data="groupedData"
    :render-content="renderFunc"
    :titles="['可選數(shù)據(jù)', '已選數(shù)據(jù)']"
  />
</template>
<script setup>
import { ref } from 'vue';
const selectedData = ref([]);
// 分組數(shù)據(jù)格式
const groupedData = ref([
  {
    key: 'group1',
    label: '第一組',
    disabled: false,
    children: [
      { key: '1', label: '選項1' },
      { key: '2', label: '選項2' }
    ]
  },
  {
    key: 'group2',
    label: '第二組',
    disabled: false,
    children: [
      { key: '3', label: '選項3' },
      { key: '4', label: '選項4' }
    ]
  }
]);
// 扁平化數(shù)據(jù)供Transfer使用
const flatData = computed(() => {
  return groupedData.value.flatMap(group => 
    group.children.map(item => ({
      key: item.key,
      label: item.label,
      disabled: item.disabled
    }))
  );
});
// 自定義渲染函數(shù)
const renderFunc = (h, option) => {
  // 這里可以自定義渲染邏輯
  return h('div', option.label);
};
</script>

2. 完全自定義左右面板

如果需要更復雜的分組效果,可以完全自定義左右面板:

<template>
  <div class="custom-transfer">
    <div class="transfer-panel">
      <div class="panel-header">可選數(shù)據(jù)</div>
      <div class="panel-body">
        <div v-for="group in leftGroups" :key="group.key" class="group">
          <div class="group-title">{{ group.label }}</div>
          <div class="group-items">
            <el-checkbox 
              v-for="item in group.children" 
              :key="item.key"
              v-model="item.checked"
              :label="item.label"
              @change="handleLeftChange(item)"
            />
          </div>
        </div>
      </div>
    </div>
    <div class="transfer-buttons">
      <el-button @click="moveToRight">→</el-button>
      <el-button @click="moveToLeft">←</el-button>
    </div>
    <div class="transfer-panel">
      <div class="panel-header">已選數(shù)據(jù)</div>
      <div class="panel-body">
        <div v-for="group in rightGroups" :key="group.key" class="group">
          <div class="group-title">{{ group.label }}</div>
          <div class="group-items">
            <el-checkbox 
              v-for="item in group.children" 
              :key="item.key"
              v-model="item.checked"
              :label="item.label"
              @change="handleRightChange(item)"
            />
          </div>
        </div>
      </div>
    </div>
  </div>
</template>
<script setup>
import { ref, computed } from 'vue';
// 原始分組數(shù)據(jù)
const rawData = ref([
  {
    key: 'group1',
    label: '第一組',
    children: [
      { key: '1', label: '選項1', checked: false },
      { key: '2', label: '選項2', checked: false }
    ]
  },
  {
    key: 'group2',
    label: '第二組',
    children: [
      { key: '3', label: '選項3', checked: false },
      { key: '4', label: '選項4', checked: false }
    ]
  }
]);
// 計算左側分組數(shù)據(jù)
const leftGroups = computed(() => {
  return rawData.value.map(group => ({
    ...group,
    children: group.children.filter(item => !selectedData.value.includes(item.key))
  }));
});
// 計算右側分組數(shù)據(jù)
const rightGroups = computed(() => {
  const selectedKeys = selectedData.value;
  return rawData.value
    .map(group => ({
      ...group,
      children: group.children.filter(item => selectedKeys.includes(item.key))
    }))
    .filter(group => group.children.length > 0);
});
// 移動選中項到右側
const moveToRight = () => {
  rawData.value.forEach(group => {
    group.children.forEach(item => {
      if (item.checked && !selectedData.value.includes(item.key)) {
        selectedData.value.push(item.key);
        item.checked = false;
      }
    });
  });
};
// 移動選中項到左側
const moveToLeft = () => {
  rawData.value.forEach(group => {
    group.children.forEach(item => {
      if (item.checked && selectedData.value.includes(item.key)) {
        const index = selectedData.value.indexOf(item.key);
        selectedData.value.splice(index, 1);
        item.checked = false;
      }
    });
  });
};
</script>
<style scoped>
.custom-transfer {
  display: flex;
  align-items: center;
}
.transfer-panel {
  width: 250px;
  border: 1px solid #ebeef5;
  border-radius: 4px;
}
.panel-header {
  padding: 10px;
  background: #f5f7fa;
  border-bottom: 1px solid #ebeef5;
}
.panel-body {
  padding: 10px;
  height: 300px;
  overflow: auto;
}
.group {
  margin-bottom: 15px;
}
.group-title {
  font-weight: bold;
  margin-bottom: 5px;
}
.transfer-buttons {
  margin: 0 10px;
}
</style>

3. 使用插槽自定義內(nèi)容

Element Plus 的 Transfer 組件提供了插槽來自定義內(nèi)容:

<el-transfer v-model="value" :data="data">
  <template #left-footer>
    <el-button size="small">操作</el-button>
  </template>
  <template #right-footer>
    <el-button size="small">操作</el-button>
  </template>
</el-transfer>

4. 結合 Tree 組件實現(xiàn)樹形分組

如果需要樹形分組,可以結合 Tree 組件來實現(xiàn):

<template>
  <div class="tree-transfer">
    <div class="left-panel">
      <el-tree
        :data="treeData"
        show-checkbox
        node-key="id"
        ref="leftTree"
        @check-change="handleCheckChange"
      />
    </div>
    <div class="transfer-buttons">
      <el-button @click="moveToRight">→</el-button>
      <el-button @click="moveToLeft">←</el-button>
    </div>
    <div class="right-panel">
      <el-tree
        :data="selectedTreeData"
        show-checkbox
        node-key="id"
        ref="rightTree"
      />
    </div>
  </div>
</template>

到此這篇關于Vue3 + Element Plus Transfer 穿梭框自定義分組的文章就介紹到這了,更多相關Vue3 Element Plus Transfer 穿梭框內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 詳解Vuex管理登錄狀態(tài)

    詳解Vuex管理登錄狀態(tài)

    這篇文章主要介紹了詳解Vuex管理登錄狀態(tài),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • vue下axios攔截器token刷新機制的實例代碼

    vue下axios攔截器token刷新機制的實例代碼

    這篇文章主要介紹了vue下axios攔截器token刷新機制的實例代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-01-01
  • vue的toast彈窗組件實例詳解

    vue的toast彈窗組件實例詳解

    本文通過實例給大家講解了vue的toast彈窗組件功能,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友參考下吧
    2018-05-05
  • 詳解vue組件開發(fā)腳手架

    詳解vue組件開發(fā)腳手架

    本篇文章給大家詳細分析了vue組件開發(fā)腳手架的相關內(nèi)容以及知識點,對此有興趣的朋友可以學習參考下。
    2018-06-06
  • Vue程序調(diào)試的方法

    Vue程序調(diào)試的方法

    這篇文章主要介紹了VUE程序調(diào)試的方法,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-06-06
  • 三分鐘讓你快速學會axios在vue項目中的基本用法(推薦!)

    三分鐘讓你快速學會axios在vue項目中的基本用法(推薦!)

    Axios是一個基于Promise用于瀏覽器和nodejs的HTTP客戶端,下面這篇文章主要給大家介紹了如何通過三分鐘讓你快速學會axios在vue項目中的基本用法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-04-04
  • Vue動態(tài)路由緩存不相互影響的解決辦法

    Vue動態(tài)路由緩存不相互影響的解決辦法

    這篇文章主要介紹了Vue動態(tài)路由緩存不相互影響的解決辦法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-02-02
  • Vue echarts封裝實現(xiàn)流程

    Vue echarts封裝實現(xiàn)流程

    這篇文章主要介紹了Vue echarts封裝的實現(xiàn),Echarts,它是一個與框架無關的JS圖表庫,但是它基于JS,這樣很多框架都能使用它
    2023-01-01
  • vue.js路由的基本使用方式

    vue.js路由的基本使用方式

    VueRouter是Vue.js的官方路由插件,用于實現(xiàn)單頁應用的頁面切換和導航,通過安裝、配置路由規(guī)則、定義路由組件和使用&amp;lt;router-link&gt;、&amp;lt;router-view&gt;標簽
    2025-01-01
  • element step組件在另一側加時間軸顯示

    element step組件在另一側加時間軸顯示

    本文主要介紹了element step組件在另一側加時間軸顯示,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-06-06

最新評論