Vue拖拽组件列表实现动态页面配置功能


Posted in Javascript onJune 17, 2019

需求描述

最近在做一个后台系统,有一个功能产品需求是页面分为左右两部分,通过右边的组件列表来动态配置左边的页面视图,并且左边由组件拼装起来的视图,可以实现上下拖拽改变顺序,也可以删除。

根据这个需求我做了下面这个demo。

功能分解

  • 右边的组件列表,可以通过拖拽克隆到左边,拖拽结束后右边组件列表数量不会减少
  • 左边的组件可以展开或收起
  • 左边的组件可以上下拖拽,删除,但不可向右边拖拽
  • 左边组件拖拽过程中不改变其展开和收起状态

demo截图

Vue拖拽组件列表实现动态页面配置功能

代码地址

vue-draggable-list

代码预览

<template>
 <div class="row">
  <div class="col-5">
   <h3>组件配置页面展示</h3>
   <draggable
    tag="el-collapse"
    class="dragArea list-group"
    :list="list2"
    group="comp"
    @change="log"
   >
    <el-collapse
     class="list-group-item left"
     v-for="(element,index) in list2"
     :key="index"
     v-model="activeNames"
     @change="handleChange"
    >
     <el-collapse-item :name="element.id">
      <template slot="title">
       <span>{{element.name}}</span>
       <i class="el-icon-circle-close" @click.stop="deleteItem(index)"></i>
      </template>
      <div>{{ element.content }}</div>
     </el-collapse-item>
    </el-collapse>
   </draggable>
  </div>
  <div class="col-5">
   <h3>可用组件列表</h3>
   <draggable
    class="dragArea list-group"
    :list="list1"
    :group="{ name: 'comp', pull: 'clone', put: false }"
    @change="log"
   >
    <div class="list-group-item" v-for="element in list1" :key="element.id">{{ element.name }}</div>
   </draggable>
  </div>
 </div>
</template>
<script>
import draggable from "vuedraggable";
export default {
 name: "clone",
 display: "Clone",
 order: 2,
 components: {
  draggable
 },
 data() {
  return {
   list1: [
    { name: "组件1", id: 1, content: "内容内容内容。。。。" },
    { name: "组件2", id: 2, content: "内容内容内容。。。。" },
    { name: "组件3", id: 3, content: "内容内容内容。。。。" },
    { name: "组件4", id: 4, content: "内容内容内容。。。。" },
    { name: "组件5", id: 5, content: "内容内容内容。。。。" },
    { name: "组件6", id: 6, content: "内容内容内容。。。。" },
    { name: "组件7", id: 7, content: "内容内容内容。。。。" }
   ],
   list2: [],
   activeNames: [],
   count: 0
  };
 },
 methods: {
  log: function(evt) {
   console.log(evt);
   if (evt.added) {
    this.count += 1;
    const item = evt.added.element;
    const idx = this.list2.findIndex(e => e.id === item.id);
    let temp = JSON.parse(JSON.stringify(this.list2));
    temp[idx].id = this.count;
    this.list2 = temp;
   }
  },
  handleChange: function() {},
  deleteItem: function(index) {
   this.list2.splice(index, 1);
  }
 }
};
</script>

总结

以上所述是小编给大家介绍的Vue拖拽组件列表实现动态页面配置功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
JavaScript 面向对象的 私有成员和公开成员
May 13 Javascript
从零学JS之你需要了解的几本书
May 19 Javascript
加载列表时jquery获取ul中第一个li的属性
Nov 02 Javascript
深入理解JavaScript内置函数
Jun 03 Javascript
JavaScript类型系统之布尔Boolean类型详解
Jun 26 Javascript
AngularJS模块详解及示例代码
Aug 17 Javascript
vue-router实现tab标签页(单页面)详解
Oct 17 Javascript
写一个移动端惯性滑动&amp;回弹Vue导航栏组件 ly-tab
Mar 06 Javascript
angularJS实现不同视图同步刷新详解
Oct 09 Javascript
微信小程序学习笔记之本地数据缓存功能详解
Mar 29 Javascript
微信小程序判断页面是否从其他页面返回的实例代码
Jul 03 Javascript
解决layer.prompt无效的问题
Sep 24 Javascript
javascript实现日历效果
Jun 17 #Javascript
如何使用Node.js爬取任意网页资源并输出PDF文件到本地
Jun 17 #Javascript
javascript使用substring实现的展开与收缩文字功能示例
Jun 17 #Javascript
vue+element加入签名效果(移动端可用)
Jun 17 #Javascript
详解Vue.js中引入图片路径的几种方式
Jun 17 #Javascript
最简单的vue消息提示全局组件的方法
Jun 16 #Javascript
如何进行微信公众号开发的本地调试的方法
Jun 16 #Javascript
You might like
BBS(php &amp; mysql)完整版(一)
2006/10/09 PHP
wordpress之wp-settings.php
2007/08/17 PHP
openPNE常用方法分享
2011/11/29 PHP
php switch语句多个值匹配同一代码块的实现
2014/03/03 PHP
ThinkPHP3.1新特性之Action参数绑定
2014/06/19 PHP
JavaScript中的类继承
2010/11/25 Javascript
基于jQuery的获取标签名的代码
2012/07/16 Javascript
分享一个我自己写的ToolTip提示插件(附源码)
2013/01/20 Javascript
jQuery实现Flash效果上下翻动的中英文导航菜单代码
2015/09/22 Javascript
JavaScript文本框脚本编写的注意事项
2016/01/25 Javascript
在JavaScript中调用Java类和接口的方法
2016/09/07 Javascript
AngularJS 防止页面闪烁的方法
2017/03/09 Javascript
vue.js中Vue-router 2.0基础实践教程
2017/05/08 Javascript
PostgreSQL Node.js实现函数计算方法示例
2019/02/12 Javascript
微信小程序时间戳转日期的详解
2019/04/30 Javascript
vue使用nprogress实现进度条
2019/12/09 Javascript
ES6函数和数组用法实例分析
2020/05/23 Javascript
angular共享依赖的解决方案分享
2020/10/15 Javascript
Django 浅谈根据配置生成SQL语句的问题
2018/05/29 Python
Django中的Model操作表的实现
2018/07/24 Python
django+tornado实现实时查看远程日志的方法
2019/08/12 Python
对python中UDP,socket的使用详解
2019/08/22 Python
python 生成器和迭代器的原理解析
2019/10/12 Python
python 上下文管理器及自定义原理解析
2019/11/19 Python
在python中利用pycharm自定义代码块教程(三步搞定)
2020/04/15 Python
python文件路径操作方法总结
2020/12/21 Python
Pycharm在指定目录下生成文件和删除文件的实现
2020/12/28 Python
英国最专业的健身器材供应商之一:Best Gym Equipment
2017/12/22 全球购物
如何使用PHP session
2015/04/21 面试题
财务管理专业自荐信范文
2013/12/24 职场文书
上课看小说检讨书
2014/02/22 职场文书
电子银行业务授权委托书
2014/10/10 职场文书
电影焦裕禄观后感
2015/06/09 职场文书
2016年机关单位节能宣传周活动总结
2016/04/05 职场文书
导游词之台湾阿里山
2019/10/23 职场文书
Redis如何实现分布式锁
2021/08/23 Redis