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组件中节流函数的失效的原因和解决方法
Dec 02 Vue.js
Vue过滤器,生命周期函数和vue-resource简单介绍
Jan 12 Vue.js
如何在 Vue 表单中处理图片
Jan 26 Vue.js
深入了解Vue动态组件和异步组件
Jan 26 Vue.js
vue.js实现点击图标放大离开时缩小的代码
Jan 27 Vue.js
Vue+Bootstrap实现简易学生管理系统
Feb 09 Vue.js
Vue包大小优化的实现(从1.72M到94K)
Feb 18 Vue.js
vue Element-ui表格实现树形结构表格
Jun 07 Vue.js
Vue + iView实现Excel上传功能的完整代码
Jun 22 Vue.js
vue实现锚点定位功能
Jun 29 Vue.js
vue中 this.$set的使用详解
Nov 17 Vue.js
vue使用watch监听属性变化
Apr 30 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
做个自己站内搜索引擎
2006/10/09 PHP
php chr() ord()中文截取乱码问题解决方法
2008/09/08 PHP
PHP 数组基础知识小结
2010/08/20 PHP
php+mysql实现无限分类实例详解
2015/01/15 PHP
PHP aes (ecb)解密后乱码问题
2015/06/22 PHP
PHP使用PhpSpreadsheet操作Excel实例详解
2020/03/26 PHP
关于jQuery中的each方法(jQuery到底干了什么)
2014/03/05 Javascript
js实现简单的验证码
2015/12/25 Javascript
原生js制作日历控件实例分享
2016/04/06 Javascript
View.post() 不靠谱的地方你知道多少
2017/08/29 Javascript
vue环境搭建简单教程
2017/11/07 Javascript
微信小程序通过保存图片分享到朋友圈功能
2018/05/24 Javascript
javascript跳转与返回和刷新页面的实例代码
2019/11/20 Javascript
[01:36]DOTA2完美大师赛趣味视频之与队友相处的十万个技巧
2017/11/19 DOTA
[51:43]OG vs LGD 2018国际邀请赛淘汰赛BO3 第五场 8.26
2018/08/30 DOTA
python多线程编程方式分析示例详解
2013/12/06 Python
Python写入数据到MP3文件中的方法
2015/07/10 Python
Python的string模块中的Template类字符串模板用法
2016/06/27 Python
Python实现变量数值交换及判断数组是否含有某个元素的方法
2017/09/18 Python
Django中ORM表的创建和增删改查方法示例
2017/11/15 Python
Python实现矩阵加法和乘法的方法分析
2017/12/19 Python
Python实现将MySQL数据库表中的数据导出生成csv格式文件的方法
2018/01/11 Python
Python编程快速上手——疯狂填词程序实现方法分析
2020/02/29 Python
Python bisect模块原理及常见实例
2020/06/17 Python
浅谈keras.callbacks设置模型保存策略
2020/06/18 Python
Python制作简单的剪刀石头布游戏
2020/12/10 Python
html+js 实现markdown编辑器效果
2019/10/23 HTML / CSS
Speedo速比涛法国官方网站:泳衣、泳镜、泳帽、泳裤
2019/07/30 全球购物
优秀中专生推荐信
2013/11/17 职场文书
医学专业毕业生个人求职信
2013/12/25 职场文书
小学美术教学反思
2014/02/01 职场文书
师范毕业生求职信
2014/07/11 职场文书
安全教育的主题班会
2015/08/13 职场文书
品牌形象定位,全面分析
2019/07/23 职场文书
导游词之台湾安平古堡
2019/12/25 职场文书
基于Python和openCV实现图像的全景拼接详细步骤
2021/10/05 Python