vue3+typeScript穿梭框的实现示例


Posted in Vue.js onDecember 29, 2020

前言

实现功能:模仿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的第一条数据',
        disabled: false,
      }, {
        label: '列表2的第二条数据',
        disabled: false,
      }],
      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, 1);
        });
        //清空
        data.checkLeft = [];
        data.checkRight = [];
      },
      //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穿梭框内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Vue.js 相关文章推荐
Vue 的 v-model用法实例
Nov 23 Vue.js
vue 在单页面应用里使用二级套嵌路由
Dec 19 Vue.js
通过vue.extend实现消息提示弹框的方法记录
Jan 07 Vue.js
详解vue中v-for的key唯一性
May 15 Vue.js
vue-router中hash模式与history模式的区别
Jun 23 Vue.js
vue使用Google Recaptcha验证的实现示例
Aug 23 Vue.js
Vue3中的Refs和Ref详情
Nov 11 Vue.js
Vue.js中v-for指令的用法介绍
Mar 13 Vue.js
深入讲解Vue中父子组件通信与事件触发
Mar 22 Vue.js
vue实现列表拖拽排序的示例代码
Apr 08 Vue.js
分享一个vue实现的记事本功能案例
Apr 11 Vue.js
如何优化vue打包文件过大
Apr 13 Vue.js
Vue.extend 登录注册模态框的实现
Dec 29 #Vue.js
vue实现简易的双向数据绑定
Dec 29 #Vue.js
vue中配置scss全局变量的步骤
Dec 28 #Vue.js
为什么推荐使用JSX开发Vue3
Dec 28 #Vue.js
Vue仿百度搜索功能
Dec 28 #Vue.js
vue中watch的用法汇总
Dec 28 #Vue.js
浅析vue中的nextTick
Dec 28 #Vue.js
You might like
php数组编码转换示例详解
2014/03/11 PHP
php自定文件保存session的方法
2014/12/10 PHP
PHP时间和日期函数详解
2015/05/08 PHP
在IIS下安装PHP扩展的方法(超简单)
2017/04/10 PHP
一个判断email合法性的函数[非正则]
2008/12/09 Javascript
JQuery 遮罩层实现(mask)实现代码
2010/01/09 Javascript
jquery URL参数判断,确定菜单样式
2010/05/31 Javascript
EASYUI TREEGRID异步加载数据实现方法
2012/08/22 Javascript
JavaScript获取onclick、onchange等事件值的代码
2013/07/22 Javascript
关于IE中getElementsByClassName不能用的问题解决方法
2013/08/26 Javascript
JS版的date函数(和PHP的date函数一样)
2014/05/12 Javascript
JS使用eval解析JSON的注意事项分析
2015/11/14 Javascript
JavaScript必知必会(六) delete in instanceof
2016/06/08 Javascript
使用bootstrap实现多窗口和拖动效果
2016/09/22 Javascript
JavaScript正则表达式exec/g实现多次循环用法示例
2017/01/17 Javascript
p5.js入门教程之鼠标交互的示例
2018/03/16 Javascript
vue与原生app的对接交互的方法(混合开发)
2018/11/28 Javascript
JavaScript中concat复制数组方法浅析
2019/01/20 Javascript
自定义Vue组件打包、发布到npm及使用教程
2019/05/22 Javascript
JS前端知识点总结之页面加载事件,数组操作,DOM节点操作,循环和分支
2019/07/04 Javascript
js判断复选框是否选中的方法示例【基于jQuery】
2019/10/10 jQuery
深入理解Python中的元类(metaclass)
2015/02/14 Python
python实现同时给多个变量赋值的方法
2015/04/30 Python
详解DeBug Python神级工具PySnooper
2019/07/03 Python
Python编程实现tail-n查看日志文件的方法
2019/07/08 Python
Python编程快速上手——Excel到CSV的转换程序案例分析
2020/02/28 Python
PageFactory设计模式基于python实现
2020/04/14 Python
荷兰在线体育用品商店:Avantisport.nl
2018/07/04 全球购物
Bodum官网:咖啡和茶壶、玻璃器皿、厨房电器等
2018/08/01 全球购物
Linux如何修改文件和文件夹的权限
2012/06/27 面试题
求职简历自荐信
2014/06/18 职场文书
“四风”问题整改措施和努力方向
2014/09/20 职场文书
教师党员先进性教育自我剖析材料思想汇报
2014/09/24 职场文书
运动会通讯稿300字
2015/07/20 职场文书
python中Tkinter 窗口之输入框和文本框的实现
2021/04/12 Python
5个实用的JavaScript新特性
2022/06/16 Javascript