利用vue-gird-layout 制作可定制桌面 (二)
添加资源池

根据项目需求 添加,

实例两个数据
{
"mainData": [
{
"x": 0,
"y": 0,
"w": 4,
"h": 4,
"i": 0,
"Component": "planExecution",
"IsResource": false
}
]
}
layoutData.json
{
"mainData": [{
"x": 0,
"y": 0,
"w": 2,
"h": 2,
"i": 0,
"Component": "productionLine",
"IsResource": true
},
{
"x": 0,
"y": 0,
"w": 2,
"h": 2,
"i": 0,
"Component": "takeTime",
"IsResource": true
},
{
"x": 0,
"y": 0,
"w": 4,
"h": 2,
"i": 0,
"Component": "yieldStatistics",
"IsResource": true
}
]
}
resourcesData.json
引到页面中
import layoutData from '@/virtualData/layoutData.json'
import resourcesData from '@/virtualData/resourcesData.json'
增加 资源数据 并且给页面数据 赋值
// 初始化数据
init() {
this.layoutData = layoutData.mainData
this.ResourceData = resourcesData.mainData
}
初始化页面之后,把资源池数据添加到页面数据中
// 打开资源池
OpenResource() {
// 资源起始点
const x = 12
// 计算向下高度
let y = 0
// 是否行并行
let wFlag = false
// 并行高度
let tempY = 0
const Resource = this.ResourceData
for (const item of Resource) {
if (item.w === 2) {
if (wFlag) {
// 第二个并行
item.x = x + 2
item.y = tempY
tempY = false
} else {
// 第一个并行行
item.x = x
item.y = y
tempY = y
wFlag = true
}
} else {
item.x = x
item.y = y
}
item.i = this.layoutConfig.index
y += item.h
this.layoutConfig.index += 1
}
this.layoutData = this.layoutData.concat(Resource)
this.historyLayout = JSON.parse(JSON.stringify(this.layoutData))
},

然后把资源池和页面数据分开,并且加上校验。

<div class="Main_border" v-if="layoutConfig.ToolVisible">
</div>
.Main_border {
height: 75%;
width: 75%;
position: absolute;
box-sizing: border-box;
border: 1px solid #000000;
}
加上分割线,然后添加移动监听。

// 监听组件移动结束位置
movedEvent(i, newX) {
const item = this.layoutData.find(t => t.i === i)
const itemW = item.w
if (newX + itemW <= 12) { // 放到线中 允许添加
console.log('放到线中 允许添加')
item.IsResource = false
this.historyLayout = JSON.parse(JSON.stringify(this.layoutData))
} else if (newX >= 12) { // 不在线中 允许添加
this.historyLayout = JSON.parse(JSON.stringify(this.layoutData))
item.IsResource = true
console.log('不在线中 允许添加')
} else { // 压线 禁止添加
this.layoutData = JSON.parse(JSON.stringify(this.historyLayout))
console.log('压线 禁止添加')
}
}

利用vue-gird-layout 制作可定制桌面 (二)的更多相关文章
- 利用vue-gird-layout 制作可定制桌面 (一)
安装 vue-gird-layout https://github.com/jbaysolutions/vue-grid-layout 先跑一遍demo 运行起来. # install with np ...
- 使用vue全家桶制作博客网站
前面的话 笔者在做一个完整的博客上线项目,包括前台.后台.后端接口和服务器配置.本文将详细介绍使用vue全家桶制作的博客网站 概述 该项目是基于vue全家桶(vue.vue-router.vuex.v ...
- 转载: 使用vue全家桶制作博客网站 HTML5 移动网站制作的好教程
使用vue全家桶制作博客网站 前面的话 笔者在做一个完整的博客上线项目,包括前台.后台.后端接口和服务器配置.本文将详细介绍使用vue全家桶制作的博客网站 概述 该项目是基于vue全家桶(vue. ...
- 一步一步教你用 Vue.js + Vuex 制作专门收藏微信公众号的 app
一步一步教你用 Vue.js + Vuex 制作专门收藏微信公众号的 app 转载 作者:jrainlau 链接:https://segmentfault.com/a/1190000005844155 ...
- 利用Vue.js实现拼图游戏
之前写过一篇<基于Vue.js的表格分页组件>的文章,主要介绍了Vue组件的编写方法,有兴趣的可以访问这里进行阅读:http://www.cnblogs.com/luozhihao/p/5 ...
- 【百度地图API】如何利用自己的数据制作社交地图?只显示可视区域内的标注
原文:[百度地图API]如何利用自己的数据制作社交地图?只显示可视区域内的标注 摘要:如果你自己的数据已经超过1万个,如何进行合理的显示?除了聚合marker外,还有一个办法.那就是,只显示可视区域内 ...
- C/S模式开发中如何利用WebBrowser控件制作导航窗体
原文:C/S模式开发中如何利用WebBrowser控件制作导航窗体 转自: CSDN 相信不少同学们都做过MIS系统的开发,今天这里不讨论B/S模式开发的问题.来谈谈winform开发.用过市面上常见 ...
- 利用css+原生js制作简易钟表
利用css+原生js制作简单的钟表.效果如下所示 实现该效果,分三大块:html.javascript.css html部分html部分比较简单,定义一个clock的div,内部有原点.时分秒针.日期 ...
- 利用U盘启动制作GHO镜像
利用U盘启动制作GHO镜像 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. In a realproduction environment. 我们我们可能遇到频繁的安装系统,安装环境 ...
随机推荐
- 推荐一个同步Mysql数据到Elasticsearch的工具
把Mysql的数据同步到Elasticsearch是个很常见的需求,但在Github里找到的同步工具用起来或多或少都有些别扭. 例如:某记录内容为"aaa|bbb|ccc",将其按 ...
- BA-WG-调试经验
Modbus网关 目前常用的产品为BAM360,仅可以用做modbus RTU主站,可以从从站扫描数据,接入的数据必须为标准的MODBUS RTU从站 串口数据 使用sc-431硬件将串口数据转换为m ...
- 韩国 DBA 博客
http://mysqldba.tistory.com/ http://cafe.naver.com/mysqlpg http://cafe.naver.com/realmysql http://wi ...
- HDU 2295
二分答案+重复覆盖.注意返回的条件哦,不能光套模板. #include <iostream> #include <cstdio> #include <cstring> ...
- 【android】uses-permission和permission具体解释
1.<uses-permission>: 官方描写叙述: If an application needs access to a feature protected by a permis ...
- 安装10gR2的硬件要求
1.至少1G的RAM. 2.RAM与swap关系: RAM swap 512M以上 2*RAM (非常奇怪.至少1G的RAM.还写512的 ...
- ASP怎样检測某目录是否存在,不存在则自己主动创建
ASP怎样检測某目录是否存在,不存在则自己主动创建 folder=server.mappath("/imagess") Set fso = CreateObject(" ...
- <LeetCode OJ> 326. Power of Three
326. Power of Three Question Total Accepted: 1159 Total Submissions: 3275 Difficulty: Easy 推断给定整数是否是 ...
- 一致性hash 算法 (转)
转载请说明出处:http://blog.csdn.net/cywosp/article/details/23397179 一致性哈希算法在1997年由麻省理工学院提出的一种分布式哈希(DHT) ...
- Vue.js和Nodejs的关系
首先vue.js 是库,不是框架,不是框架,不是框架. Vue.js 使用了基于 HTML 的模版语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据. Vue.js 的核心是一个允许你 ...