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设计模式之观察者模式(发布者-订阅者模式)
Sep 24 Javascript
js继承call()和apply()方法总结
Dec 08 Javascript
JavaScript判断FileUpload控件上传文件类型
Sep 28 Javascript
JavaScript中的prototype原型学习指南
May 09 Javascript
jQuery解决$符号命名冲突
Jun 18 Javascript
jQuery实现可展开折叠的导航效果示例
Sep 12 Javascript
基于Vue2实现简易的省市区县三级联动组件效果
Nov 05 Javascript
jQuery子选择器与可见性选择器实例分析
Jun 28 jQuery
laypage+SpringMVC实现后端分页
Jul 27 Javascript
Node.js之删除文件夹(含递归删除)代码实例
Sep 09 Javascript
jQuery 实现扁平式小清新导航
Jul 07 jQuery
解决vue中使用less/sass及使用中遇到无效的问题
Oct 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
PHP simple_html_dom.php+正则 采集文章代码
2009/12/24 PHP
php编译安装php-amq扩展简明教程
2016/06/25 PHP
PHP对称加密算法(DES/AES)类的实现代码
2017/11/14 PHP
php+js实现的拖动滑块验证码验证表单操作示例【附源码下载】
2020/05/27 PHP
JavaScript高级程序设计 读书笔记之十 本地对象Date日期
2012/02/27 Javascript
javascript数组遍历for与for in区别详解
2014/12/04 Javascript
jQuery取得iframe中元素的常用方法详解
2016/01/14 Javascript
jquery对象和DOM对象的任意相互转换
2016/02/21 Javascript
JS实现拖拽的方法分析
2016/12/20 Javascript
对比分析Django的Q查询及AngularJS的Datatables分页插件
2017/02/07 Javascript
利用imgareaselect辅助后台实现图片上传裁剪
2017/03/02 Javascript
zTree jQuery 树插件的使用(实例讲解)
2017/09/25 jQuery
JS兼容所有浏览器的DOMContentLoaded事件
2018/01/12 Javascript
jQuery实现的简单对话框拖动功能示例
2018/06/05 jQuery
axios使用拦截器统一处理所有的http请求的方法
2018/11/02 Javascript
jQuery实现的模仿雨滴下落动画效果
2018/12/11 jQuery
JavaScript中的回调函数实例讲解
2019/01/27 Javascript
JavaScript中filter的用法实例分析
2019/02/27 Javascript
微信小程序如何调用新闻接口实现列表循环
2019/07/02 Javascript
简述ES6新增关键字let与var的区别
2019/08/23 Javascript
使用 JavaScript 创建并下载文件(模拟点击)
2019/10/25 Javascript
Vue关于组件化开发知识点详解
2020/05/13 Javascript
vue 解决setTimeOut和setInterval函数无效报错的问题
2020/07/30 Javascript
vue前端和Django后端如何查询一定时间段内的数据
2021/02/28 Vue.js
Python实现将MySQL数据库表中的数据导出生成csv格式文件的方法
2018/01/11 Python
Python 窗体(tkinter)按钮 位置实例
2019/06/13 Python
关于tf.matmul() 和tf.multiply() 的区别说明
2020/06/18 Python
《美丽的田园》教学反思
2014/03/01 职场文书
男女朋友协议书
2014/04/23 职场文书
班组建设经验交流材料
2014/05/12 职场文书
学生乘坐校车安全责任书
2015/05/11 职场文书
荒岛余生观后感
2015/06/09 职场文书
校园音乐节目广播稿
2015/08/19 职场文书
血轮眼轮回眼特效 html+css
2021/03/31 HTML / CSS
nginx对http请求处理的各个阶段详析
2021/03/31 Servers
MySQL创建管理子分区
2022/04/13 MySQL