利用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. 我们我们可能遇到频繁的安装系统,安装环境 ...
随机推荐
- 解决MyEclipse开启后总是不停的在Update index
近期MyEclipse开启之后总是不停的在 update index,非常是耗时间. 查找资料发现Update index...是Maven在不断更新, 解决的方法例如以下: Window --> ...
- ZOJ 1654--Place the Robots【二分匹配 && 经典建图】
Place the Robots Time Limit: 5 Seconds Memory Limit: 32768 KB Robert is a famous engineer. One ...
- 在Windows 8.1系统上配置免安装版mysql-5.6.21-winx64
1.到官网上下载MySQL 下载地址为:http://cdn.mysql.com/Downloads/MySQL-5.6/mysql-5.6.21-winx64.zip 2.解压文件到D盘 当然你可以 ...
- luogu1120 小木棍【数据加强版】 暴力剪枝
题目大意 乔治有一些同样长的小木棍,他把这些木棍随意砍成几段,直到每段的长都不超过50.现在,他想把小木棍拼接成原来的样子,但是却忘记了自己开始时有多少根木棍和它们的长度.给出每段小木棍的长度,编程帮 ...
- c25---条件编译
// // main.c // 条件编译(宏定义是简单的替换,要给参数和结果都加括号) #include <stdio.h> #define SCORE 90 #define DEBUG ...
- php study80端口被占用
php study80端口被占用 在网上找了各种办法,说是用命令查看占用端口的软件,将其停止,我发现我的端口是被system进程占用,而且这进程还结束不了. 1.打开PHPstudy,如图:打开端口常 ...
- 登录linux,输入ls显示anaconda-ks.cfg cobbler.ks ....., 原因在于root@ ~ / 区别
今天登录linux测试机,想要创建目录,ls的时候,找不到之前的的目录,才发现是目录不对的问题. 首先,先要弄清楚 [root@330c353813ea ~] 和 [root@330c353813ea ...
- <Android Framework 之路>Android5.1 MediaScanner
前言 MediaScanner是Android系统中针对媒体文件的扫描过程,将储存空间中的媒体文件通过扫描的方式遍历并存储在数据库中,然后通过MediaProvider提供接口使用,在Android多 ...
- android黑科技系列——破解游戏之修改金币数
我们在玩游戏的时候总是会遇到一些东东需要进行购买的,但是我们可能又舍不得花钱,那么我们该怎么办呢?那就是用游戏外挂吧!我们这里说的是Android中的游戏,在网上搜索一下移动端游戏外挂,可能会找到一款 ...
- MVC:@RenderBody、@RenderPage、@RenderSection用法
本文导读:在Razor引擎中没有了“母版页”,取而代之的是叫做“布局”的页面(_Layout.cshtml)放在了共享视图文件夹中.模板页:@RenderBody()占位符:局部页面:@RenderP ...