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 相关文章推荐
js 事件小结 表格区别
Aug 13 Javascript
jQuery Ajax之load()方法
Oct 12 Javascript
js获取某月的最后一天日期的简单实例
Jun 22 Javascript
javascript简单实现命名空间效果
Mar 06 Javascript
JavaScript中在光标处插入添加文本标签节点的详细方法
Mar 22 Javascript
bootstrap精简教程_动力节点Java学院整理
Jul 14 Javascript
angular或者js怎么确定选中ul中的哪几个li
Aug 16 Javascript
JavaScript代码判断输入的字符串是否含有特殊字符和表情代码实例
Aug 17 Javascript
JS实现基于拖拽改变物体大小的方法
Jan 23 Javascript
element ui 对话框el-dialog关闭事件详解
Feb 26 Javascript
npm scripts 使用指南详解
Oct 08 Javascript
在HTML中使用JavaScript的两种方法
Dec 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
不用数据库的多用户文件自由上传投票系统(1)
2006/10/09 PHP
一步一步学习PHP(5) 类和对象
2010/02/16 PHP
PHP无敌近乎加密方式!
2010/07/17 PHP
微信公众号开发之文本消息自动回复php代码
2016/08/08 PHP
PHP封装的分页类与简单用法示例
2019/02/25 PHP
用html+css+js实现的一个简单的图片切换特效
2014/05/28 Javascript
jQuery简易图片放大特效示例代码
2014/06/09 Javascript
javascript原生和jquery库实现iframe自适应高度和宽度
2014/07/18 Javascript
JavaScript访问CSS属性的几种方式介绍
2014/07/21 Javascript
js监听鼠标事件控制textarea输入字符串的个数
2014/09/29 Javascript
Node.js抓取中文网页乱码问题和解决方法
2015/02/10 Javascript
JavaScript中DOM详解
2015/04/13 Javascript
jQuery实现元素拖拽并cookie保存顺序的方法
2016/02/20 Javascript
JS跨域解决方案之使用CORS实现跨域
2016/04/14 Javascript
关于 jQuery Easyui异步加载tree的问题解析
2016/12/06 Javascript
JS匹配日期和时间的正则表达式示例
2017/05/12 Javascript
EasyUI的DataGrid每行数据添加操作按钮的实现代码
2017/08/22 Javascript
vue中axios的封装问题(简易版拦截,get,post)
2018/06/15 Javascript
如何为vue的项目添加单元测试
2018/12/19 Javascript
微信小程序按钮点击跳转页面详解
2019/05/06 Javascript
JavaScript学习教程之cookie与webstorage
2019/06/23 Javascript
layer弹出层扩展主题的方法
2019/09/11 Javascript
vue实现循环滚动列表
2020/06/30 Javascript
pycharm 使用心得(八)如何调用另一文件中的函数
2014/06/06 Python
零基础写python爬虫之爬虫编写全记录
2014/11/06 Python
Python定义函数实现累计求和操作
2020/05/03 Python
使用Keras建立模型并训练等一系列操作方式
2020/07/02 Python
Docker如何部署Python项目的实现详解
2020/10/26 Python
数字天堂软件测试面试题
2012/12/23 面试题
实习生自我鉴定范文
2013/12/05 职场文书
外语系毕业生自荐信范文
2013/12/16 职场文书
施工班组长岗位职责
2014/01/05 职场文书
运动会100米解说词
2014/01/23 职场文书
工作说明书格式
2014/07/29 职场文书
发布会邀请函
2015/01/31 职场文书
网吧员工管理制度
2015/08/05 职场文书