使用Vue3实现一个穿梭框效果的示例代码

 更新时间:2023年12月01日 08:46:24   作者:JacksonChen  
这篇文章主要给大家介绍了如何使用 Vue3 实现一个穿梭框效果,当选中数据,并且点击相对应的方向箭头时,选中的数据会发送到对面,并且数据会保持正确的顺序进行排列,文中有详细的代码讲解,具有一定的参考价值,需要的朋友可以参考下

效果

当选中数据,并且点击相对应的方向箭头时,选中的数据会发送到对面,并且数据会保持正确的顺序进行排列。

在线预览:https://chenyajun.fun/#/transfer

实现

左右两边逻辑一致,这里只对左侧的进行分析

先看一下 html 结构 方便理解

      <div class="module-wrapper">
        <div class="module-head">
          <span>list1</span>
          <span>{{ currentSelectLeft }}</span>
        </div>
        <div class="module-content">
          <div v-if="!listLeft.length" style="text-align: center">No data</div>
          <div class="module-item" v-for="(item, index) in listLeft" @click="handleTransferLeft(index)">
            <input style="width: 20px; height: 20px" type="checkbox" :checked="item.checked" />
            <span
              :style="{
                color: item.checked ? '#68b2ff' : '#000',
              }"
              >{{ item.label }}</span
            >
          </div>
        </div>
      </div>

数据处理

首先初始化 10 条穿梭框数据,key 属性用于排序,label 用于展示数据,最后为数据添加 checked 属性(主要用于标记是否被选中),然后将数据赋值给左边的列表 listLeft。

function getListData() {
  let data = []
  for (let index = 1; index <= 10; index++) {
    data.push({
      key: index,
      label: 'option' + index,
    })
  }

  //对data进行处理 默认我们认为没有checked属性
  data.forEach((item) => {
    item.checked = false
  })
  listLeft.value = data
}

点击状态取反

上面我们初始化了数据,下面需要做的是当点击每一项 option 的时候让状态取反。

点击 option 时只需把相应的 index 传入,然后进行取反操作即可。

// 点击进行状态取反
function handleTransferLeft(currentIndex) {
  listLeft.value[currentIndex].checked = !listLeft.value[currentIndex].checked
}

比例状态

我们看到了上面的已选数据和总数据的比例状态

先拿到已选数据

// 左侧checked的数据
const currentCheckedLeft = computed(() => {
  return listLeft.value.filter((item) => item.checked)
})

将左侧选中数据的长度 比上 数据总长度即可

点击箭头进行穿梭

// 点击右箭头
function toRight() {
  // 对选中数据进行深拷贝
  const deepCloneData = JSON.parse(JSON.stringify(currentCheckedLeft.value))
  // 把刚选择的数据状态进行清除
  deepCloneData.forEach((item) => {
    item.checked = false
  })
  // 把选中的数据添加到右边 需要把刚选择的数据状态进行清除
  listRight.value.push(...deepCloneData)
  // 对右边数据进行重新排序
  listRight.value.sort((a, b) => a.key - b.key)

  // 找到未选中数据 进行重新赋值
  const noCheckedLeftData = listLeft.value.filter((item) => !item.checked)
  listLeft.value = noCheckedLeftData
}

先对选中数据清除状态,因为如果不清除状态可能会导致穿梭过的的数据仍然还是选中。

如图所示:1,2是刚穿梭过去的数据,仍保留状态

注意需要对选中数据进行深拷贝,因为下面需要用到未选中的数据,如果不进行深拷贝,那下面再去筛选未选中的数据时就会把所有的数据选中。

  // 对选中数据进行深拷贝
  const deepCloneData = JSON.parse(JSON.stringify(currentCheckedLeft.value))
  // 把刚选择的数据状态进行清除
  deepCloneData.forEach((item) => {
    item.checked = false
  })

接下来筛选出来选中数据后,将数据添加到右边的数组 

 // 把选中的数据添加到右边 需要把刚选择的数据状态进行清除
  listRight.value.push(...deepCloneData)

然后再对右边的数组进行排序

  // 对右边数据进行重新排序
  listRight.value.sort((a, b) => a.key - b.key)

现在已经将数据穿梭到右侧,那怎么去除左侧已穿梭的数据呢?

筛选出来左边未选择的数据,重新赋值给左边数组即可

  // 找到未选中数据 进行重新赋值
  const noCheckedLeftData = listLeft.value.filter((item) => !item.checked)
  listLeft.value = noCheckedLeftData

这一步也是上面为什么深拷贝的原因。

如果不进行深拷贝,如图所示:

已经穿梭了过去,但是取未筛选数据时,因为上面的状态已经取反,这里都会选择到。

总结

我们需要知道如果要实现一个穿梭框效果,我们大概都需要做哪些东西呢?

那首先是对左侧的初始化数据,我们需要对数据进行加工,添加 checked 属性,方便后面进行筛选。

其次是我们找出我们选中的数据,添加到右侧,同时把左侧选中的数据进行移除。

源码

GitHub:https://github.com/chenyajun-create/transfer

以上就是使用Vue3实现一个穿梭框效果的示例代码的详细内容,更多关于Vue3实现穿梭框的资料请关注脚本之家其它相关文章!

相关文章

  • Vue3属性绑定方法解析

    Vue3属性绑定方法解析

    这篇文章主要介绍了Vue3属性绑定方法解析,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-09-09
  • vue实现页面切换滑动效果

    vue实现页面切换滑动效果

    这篇文章主要为大家详细介绍了vue实现页面切换滑动效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-06-06
  • 详解vue3中watch监听的几种情况

    详解vue3中watch监听的几种情况

    watch是CompositionAPI的一部分,用于监听响应式数据的变化并执行相应的操作,本文主要介绍了详解vue3中watch监听的几种情况,具有一定的参考价值,感兴趣的可以了解一下
    2025-03-03
  • vue项目中使用高德地图的超详细步骤

    vue项目中使用高德地图的超详细步骤

    在vue项目中添加高德地图,对开发地图的开发人员有一定帮助,下面这篇文章主要给大家介绍了关于vue项目中使用高德地图的超详细步骤,文中通过图文以及实例代码介绍的非常详细,需要的朋友可以参考下
    2023-03-03
  • vue elementUI 表单校验功能之数组多层嵌套

    vue elementUI 表单校验功能之数组多层嵌套

    这篇文章主要介绍了vue elementUI 表单校验(数组多层嵌套)功能的实例代码,代码简单易懂,非常不错,具有一定的参考借鉴价值 ,需要的朋友可以参考下
    2019-06-06
  • Vue+ElementUI容器无法铺满网页的问题解决

    Vue+ElementUI容器无法铺满网页的问题解决

    这篇文章主要介绍了Vue+ElementUI容器无法铺满网页的问题解决,文章通过图文结合的方式给大家讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2024-08-08
  • vue项目下npm或yarn下安装echarts多个版本方式

    vue项目下npm或yarn下安装echarts多个版本方式

    这篇文章主要介绍了vue项目下npm或yarn下安装echarts多个版本方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-06-06
  • vue3.x ref()语法糖赋值方式

    vue3.x ref()语法糖赋值方式

    这篇文章主要介绍了vue3.x ref()语法糖赋值方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • 基于Vuejs实现购物车功能

    基于Vuejs实现购物车功能

    这篇文章主要为大家详细介绍了基于Vuejs实现购物车功能的相关资料,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • vue实现excel表格的导入导出的示例

    vue实现excel表格的导入导出的示例

    本文主要介绍了vue实现excel表格的导入导出的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04

最新评论