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 相关文章推荐
基于jquery的禁用右键、文本选择功能、复制按键的实现代码
Aug 27 Javascript
javascript 获取元素样式必杀技
May 04 Javascript
jQuery学习笔记之jQuery.fn.init()的参数分析
Jun 09 Javascript
javascript:void(0)点击登录没反应怎么解决
Nov 13 Javascript
跟我学习javascript的this关键字
May 28 Javascript
javascript运算符语法全面概述
Jul 14 Javascript
微信和qq时间格式模板实例详解
Oct 21 Javascript
JavaScript引用类型Date常见用法实例分析
Aug 08 Javascript
JS继承定义与使用方法简单示例
Feb 19 Javascript
react-router-dom 嵌套路由的实现
May 02 Javascript
Vue 禁用浏览器的前进后退操作
Sep 04 Javascript
JavaScript原型链详解
Nov 07 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
PHP session有效期问题
2009/04/26 PHP
ubuntu下编译安装xcache for php5.3 的具体操作步骤
2013/06/18 PHP
phpmyadmin config.inc.php配置示例
2013/08/27 PHP
php弹出对话框实现重定向代码
2014/01/23 PHP
详解PHP函数 strip_tags 处理字符串缺陷bug
2017/06/11 PHP
Jquery截取中文字符串的实现代码
2010/12/22 Javascript
JavaScript prototype属性深入介绍
2012/11/27 Javascript
JQuery实现左右滚动菜单特效
2015/09/28 Javascript
酷炫jQuery全屏3D焦点图动画效果
2016/03/22 Javascript
Bootstrap Table表格一直加载(load)不了数据的快速解决方法
2016/09/17 Javascript
easyui datebox 时间限制,datebox开始时间限制结束时间,datebox截止日期比起始日期大的实现代码
2017/01/12 Javascript
Ionic 2 实现列表滑动删除按钮的方法
2017/01/22 Javascript
JS及JQuery对Html内容编码,Html转义
2017/02/17 Javascript
JavaScript中的工厂函数(推荐)
2017/03/08 Javascript
webpack构建换肤功能的思路详解
2017/11/27 Javascript
JS逻辑运算符短路操作实例分析
2018/07/09 Javascript
jQuery 同时获取多个标签的指定内容并储存为数组
2018/11/20 jQuery
vue+elementUi图片上传组件使用详解
2019/08/20 Javascript
nestjs中异常过滤器Exceptionfilter的具体使用
2021/02/07 Javascript
在Django中同时使用多个配置文件的方法
2015/07/22 Python
解决pycharm界面不能显示中文的问题
2018/05/23 Python
Python使用paramiko操作linux的方法讲解
2019/02/25 Python
Python模块、包(Package)概念与用法分析
2019/05/31 Python
python读取文件指定行内容实例讲解
2020/03/02 Python
解决启动django,浏览器显示“服务器拒绝访问”的问题
2020/05/13 Python
意大利灯具购物网站:Lampade.it
2018/10/18 全球购物
俄罗斯在线购买飞机票、火车票、巴士票网站:Tutu.ru
2020/03/16 全球购物
英语专业毕业生自我鉴定
2013/11/09 职场文书
数据管理员的自我评价分享
2013/11/15 职场文书
劳动争议和解协议书范本
2014/11/20 职场文书
2014年团总支工作总结
2014/11/21 职场文书
军训后的感想
2015/08/07 职场文书
小学生作文写作技巧100例,非常实用!
2019/07/08 职场文书
详解JavaScript中Arguments对象用途
2021/08/30 Javascript
python多线程方法详解
2022/01/18 Python
什么是SOLID
2022/03/24 Javascript