1. 程式人生 > 程式設計 >vue3+typeScript穿梭框的實現示例

vue3+typeScript穿梭框的實現示例

前言

實現功能:模仿element穿梭框的簡單功能
每週分享一個vue3+typeScript的小元件,我只想分享下自己的實現思路,樓主是個菜雞前端,記錄下實現過程,說不定對你有幫助。

效果展示

預覽地址

github地址

vue3+typeScript穿梭框的實現示例

開發過程

思路:用兩個陣列分別記錄左右框框裡面的值,根據複選框選中狀態來實現刪除增加即可

html部分

<div class="shuttle">
  <!-- 左邊列表 -->
  <div class="shuttle-box">
    <div class="shuttle-box-title">
      <div>列表一</div>
      <div class="index-num">{{itemLeft.length}}</div>
    </div>
    <div class="shuttle-box-list">
      <div class="shuttle-box-item" v-for="(vo,inx) in itemLeft" :key="inx">
        <input type="checkbox" :value="inx" v-model="checkLeft" :disabled="vo.disabled" /> {{vo.label}}
      </div>
    </div>
  </div>
  <!-- 左右操作按鈕 -->
  <div class="shuttle-click">
    <span @click="goLeft">←</span>
    <span @click="goRight">→</span>
  </div>
  <!-- 右邊列表 -->
  <div class="shuttle-box">
    <div class="shuttle-box-title">
      <div>列表二</div>
      <div class="index-num">{{itemRight.length}}</div>
    </div>
    <div class="shuttle-box-list">
      <div class="shuttle-box-item" v-for="(vo,inx) in itemRight" :key="inx">
        <input type="checkbox" :value="inx" v-model="checkRight" :disabled="vo.disabled" /> {{vo.label}}
      </div>
    </div>
  </div>
</div>

ts部分

<script lang="ts">
import {
  defineComponent,reactive,toRefs
} from 'vue'

export default defineComponent({
  setup() {

    const data = reactive({
      itemLeft: [{
        label: '列表1的第一條資料',disabled: true,},{
        label: '列表1的第二條資料',disabled: false,}],itemRight: [{
        label: '列表2的第一條資料',{
        label: '列表2的第二條資料',checkLeft: [],checkRight: [],goLeft: () => {
        //陣列排序
        data.checkRight.sort(data.sortIndex);
        data.checkRight.forEach((item) => {
          //將itemRight對應索引的資料移動到左邊去
          data.itemLeft.push(data.itemRight[item]);
          //移除
          data.itemRight.splice(item,1);
        });
        //清空
        data.checkLeft = [];
        data.checkRight = [];
      },goRight: () => {
        //陣列排序
        data.checkLeft.sort(data.sortIndex);
        data.checkLeft.forEach((item) => {
          //將itemLeft對應索引的資料移動到右邊去
          data.itemRight.push(data.itemLeft[item]);
          //移除
          data.itemLeft.splice(item,//checkbox是繫結的是的陣列的索引,所以checkbox的點選的順序不同的話索引的順序是不同的,這樣刪除有可能找不到會報錯,排個序從大到小刪除就可以
      //這個是排序引數
      sortIndex: (a,b) => {
        return b - a;
      }
    })
    return {
      ...toRefs(data),}
  }
})
</script>

css部分

.shuttle {
  width: 800px;
  padding: 50px 0;
  display: flex;
  justify-content: space-between;
  //整個穿梭框
  .shuttle-box {
    width: 300px;
    height: 500px;
    border: 1px solid #ddd;
    //標題
    .shuttle-box-title {
      background: #f5f7fa;
      padding: 0 20px;
      height: 40px;
      line-height: 40px;
      display: flex;
      justify-content: space-between;
      .index-num {
        color: #909399;
        font-size: 12px;
        font-weight: 400;
      }
    }
    //列表
    .shuttle-box-list {
      padding: 20px;
      //一個列表item
      .shuttle-box-item {
        line-height: 2.0;
      }
    }
  }
  //左右穿梭按鈕
  .shuttle-click {
    padding-top: 60px;
    cursor: pointer;
    span {
      padding: 5px 10px;
      display: inline-block;
      background: #409eff;
      color: #ffffff;
      margin: 0 5px;
      text-align: center;
    }
  }
}

到此這篇關於vue3+typeScript穿梭框的實現示例的文章就介紹到這了,更多相關vue3+typeScript穿梭框內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!