首页 > 编程 > JavaScript > 正文

Vue拖拽组件列表实现动态页面配置功能

2019-11-19 11:20:07
字体:
来源:转载
供稿:网友

需求描述

最近在做一个后台系统,有一个功能产品需求是页面分为左右两部分,通过右边的组件列表来动态配置左边的页面视图,并且左边由组件拼装起来的视图,可以实现上下拖拽改变顺序,也可以删除。

根据这个需求我做了下面这个demo。

功能分解

  • 右边的组件列表,可以通过拖拽克隆到左边,拖拽结束后右边组件列表数量不会减少
  • 左边的组件可以展开或收起
  • 左边的组件可以上下拖拽,删除,但不可向右边拖拽
  • 左边组件拖拽过程中不改变其展开和收起状态

demo截图


代码地址

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拖拽组件列表实现动态页面配置功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对武林网网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表