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 相关文章推荐
jQuery1.5.1 animate方法源码阅读
Apr 05 Javascript
jQuery学习笔记之入门
Dec 14 Javascript
深入理解JavaScript中的预解析
Jan 04 Javascript
express框架实现基于Websocket建立的简易聊天室
Aug 10 Javascript
深入理解vue中slot与slot-scope的具体使用
Jan 26 Javascript
详解Vue中watch对象内属性的方法
Feb 01 Javascript
javascript中floor使用方法总结
Feb 02 Javascript
使用js实现一个简单的滚动条过程解析
Sep 10 Javascript
javascript的hashCode函数实现代码小结
Aug 11 Javascript
vue路由的配置和页面切换详解
Sep 09 Javascript
Vue使用v-viewer实现图片预览
Oct 21 Javascript
在vue项目中promise解决回调地狱和并发请求的问题
Nov 09 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的String类代码
2010/04/20 PHP
php ci框架验证码实例分析
2013/06/26 PHP
Thinkphp框架开发移动端接口(1)
2016/08/18 PHP
jquery通过load获取文件的内容并跳到锚点的方法
2015/01/29 Javascript
jQuery层级选择器用法分析
2015/02/10 Javascript
jquery+html5制作超酷的圆盘时钟表
2015/04/14 Javascript
纯jquery实现模仿淘宝购物车结算
2015/08/20 Javascript
JS组件系列之Bootstrap Icon图标选择组件
2016/01/28 Javascript
nodejs 中模拟实现 emmiter 自定义事件
2016/02/22 NodeJs
jQuery实现鼠标经过像翻页和描点链接效果
2016/08/08 Javascript
JS实现间歇滚动的运动效果实例
2016/12/22 Javascript
Angular2管道Pipe及自定义管道格式数据用法实例分析
2017/11/29 Javascript
JavaScript寄生组合式继承实例详解
2018/01/06 Javascript
Vue 页面切换效果之 BubbleTransition(推荐)
2018/04/08 Javascript
vue仿element实现分页器效果
2018/09/13 Javascript
Windows下支持自动更新的Electron应用脚手架的方法
2018/12/24 Javascript
Vue框架下引入ActiveX控件的问题解决
2019/03/25 Javascript
antd vue table跨行合并单元格,并且自定义内容实例
2020/10/28 Javascript
[01:05:29]DOTA2-DPC中国联赛 正赛 PSG.LGD vs Aster BO3 第二场 1月24日
2021/03/11 DOTA
用Python实现web端用户登录和注册功能的教程
2015/04/30 Python
Python 点击指定位置验证码破解的实现代码
2019/09/11 Python
python调用Matplotlib绘制分布点图
2019/10/18 Python
python os模块在系统管理中的应用
2020/06/22 Python
解决python 虚拟环境删除包无法加载的问题
2020/07/13 Python
详解Pycharm第三方库的安装及使用方法
2020/12/29 Python
html5-canvas中使用clip抠出一个区域的示例代码
2018/05/25 HTML / CSS
简约控的天堂:The Undone
2016/12/21 全球购物
卡骆驰新加坡官网:Crocs新加坡
2018/06/12 全球购物
澳大利亚网上书店:QBD
2021/01/09 全球购物
美国在线家具网站:GDFStudio
2021/03/13 全球购物
了解AppleTalk协议吗
2014/04/01 面试题
大学毕业自我鉴定范文
2014/02/03 职场文书
二十年同学聚会致辞
2015/07/28 职场文书
企业转让协议书(范文2篇)
2019/08/15 职场文书
浅谈Nginx 中的两种限流方式
2021/03/31 Servers
《LOL》“克隆大作战”久违归来 幻灵战队皮肤上线
2022/04/03 其他游戏