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 相关文章推荐
获取Javscript执行函数名称的方法
Dec 22 Javascript
利用404错误页面实现UrlRewrite的实现代码
Aug 20 Javascript
js关闭子窗体刷新父窗体实现方法
Dec 04 Javascript
jquery与js函数冲突的两种解决方法
Sep 09 Javascript
javascript学习笔记(五)原型和原型链详解
Oct 08 Javascript
理解javascript模块化
Mar 28 Javascript
jQuery通用的全局遍历方法$.each()用法实例
Jul 04 Javascript
vue2.0全局组件之pdf详解
Jun 26 Javascript
jQuery初级教程之网站品牌列表效果
Aug 02 jQuery
JSON创建键值对(key是中文或者数字)方式详解
Aug 24 Javascript
快速处理vue渲染前的显示问题
Mar 05 Javascript
JavaScript使用prototype属性实现继承操作示例
May 22 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
香妃
2021/03/03 冲泡冲煮
PHP实现对二维数组某个键排序的方法
2016/09/14 PHP
文本框input聚焦失焦样式实现代码
2012/10/12 Javascript
文字不间断滚动(上下左右)实例代码
2013/04/21 Javascript
Node.js中使用mongoskin操作mongoDB实例
2014/09/28 Javascript
基于jQuery倾斜打开侧边栏菜单特效代码
2015/09/15 Javascript
JS动态生成年份和月份实例代码
2017/02/04 Javascript
多个上传文件用js验证文件的格式和大小的方法(推荐)
2017/03/09 Javascript
vue-cli+webpack在生成的项目中使用bootstrap实例代码
2017/05/26 Javascript
深入理解Node中的buffer模块
2017/06/03 Javascript
bootstrap选项卡扩展功能详解
2017/06/14 Javascript
nodejs+mongodb+vue前后台配置ueditor的示例代码
2018/01/02 NodeJs
去掉vue 中的代码规范检测两种方法(Eslint验证)
2018/03/21 Javascript
vue cli 3.0 使用全过程解析
2018/06/14 Javascript
vue获取data数据改变前后的值方法
2019/11/07 Javascript
JavaScript如何判断input数据类型
2020/02/06 Javascript
JavaScript代码实现简单计算器
2020/12/27 Javascript
[46:23]完美世界DOTA2联赛PWL S2 FTD vs Magma 第一场 11.20
2020/11/23 DOTA
python实现简单的TCP代理服务器
2014/10/08 Python
Python列表list排列组合操作示例
2018/12/18 Python
Python 确定多项式拟合/回归的阶数实例
2018/12/29 Python
基于pandas中expand的作用详解
2019/12/17 Python
解决Python logging模块无法正常输出日志的问题
2020/02/21 Python
Python如何批量获取文件夹的大小并保存
2020/03/31 Python
python实现飞船大战
2020/04/24 Python
精美的手工家居和生活用品:Nkuku
2019/11/01 全球购物
比较基础的php面试题及答案-编程题
2012/10/14 面试题
法院先进个人事迹材料
2014/05/04 职场文书
出差报告格式模板
2014/11/06 职场文书
2014年公司工作总结
2014/11/22 职场文书
教师节倡议书2015
2015/04/27 职场文书
开学第一天的感想
2015/08/10 职场文书
2015年学校消防安全工作总结
2015/10/14 职场文书
学生会副主席竞选稿
2015/11/19 职场文书
创业计划书之水果店
2019/07/18 职场文书
python代码实现扫码关注公众号登录的实战
2021/11/01 Python