基于vue.js 移动可视化,拖拽生成H5系统
效果预览

功能简介
基于Vue.js(2.0)版本开发的,通过拖拽可视化的操作,生成H5的页面,类似易企秀的工具,前端展示页面运用了之前发布的 vue-animate-fullpage 插件进行动画渲染。
(vue-animate-fullpage 插件 请移步 文章:https://www.cnblogs.com/luobiao/p/13292205.html)
有哪些功能?
目前只能设置背景图片、插入图片、文本(文本设置字号、颜色)等,二期以后会逐步增加更多的功能。
有哪些动画效果?
目前采用的是开源的animate.css的动画库。
拖拽核心功能实现?
通过自定义指令(v-drag) ,加上该指令的元素,就可以实现拖拽。
tips:新建自定义指令前需要清楚几个属性。
pageX 、pageY::鼠标指针的位置,文档的坐标。
offsetLeft:指 元素 距离左方或上层控件左侧的距离。
offsetTop: 指 元素 距离上方或上层控件顶部的距离。
直接上代码:
js代码:
//在main.js中自定义一个全局指令v-drag
Vue.directive('drag', {//1.指令绑定到元素上回立刻执行bind函数,只执行一次//2.每个函数中第一个参数永远是el,表示绑定指令的元素,el参数是原生js对象//3.通过el.focus()是无法获取焦点的,因为只有插入DOM后才生效bind: function (el, binding) {let oDiv = el; //获取当前元素let firstTime = '', lastTime = '';oDiv.style.position = "absolute"; //要实现拖拽,要给元素添加绝对定位(如果元素css已经加上了,此处可以省略)el.onmousedown = function (e) {//用元素距离视窗的X、Y坐标,减去当前元素最近的相对定位父元素的left、top值var disX = e.pageX - el.offsetLeft;var disY = e.pageY - el.offsetTop;oDiv.setAttribute('ele-flag', false)// 给当前元素添加属性,用于元素状态的判断oDiv.setAttribute('draging-flag', true)firstTime = new Date().getTime();document.onmousemove = function (e) {el.style.left = e.pageX - disX + 'px';//获得当前元素拖拽后的位置坐标el.style.top = e.pageY - disY + 'px';binding.value({ left: e.pageX - disX, top: e.pageY - disY }) //将拖拽后最新的坐标传递回组件内,方便组件获取使用return false;}document.onmouseup = function (event) {document.onmousemove = document.onmouseup = null; //清除 onmousemove 事件lastTime = new Date().getTime();if ((lastTime - firstTime) > 200) {oDiv.setAttribute('ele-flag', true)event.stopPropagation(); //阻止冒泡}setTimeout(function () {oDiv.setAttribute('draging-flag', false)}, 100)}}},})
组件代码
//html代码
<div id="app">
<div class="drag-box" v-drag="greet"></div> <!--v-drag是自定义指令,加上该指令的元素,可以实现拖拽--> 此处 的greet 为接收自定义指令回传坐标
</div>
js 代码
在vue的methods生命周期中调用greet 即可。
methods: {greet(val){console.log(val);}}
附上GitHub地址:https://github.com/ALazyTiger/alazytigerDragH5.git
基于vue.js 移动可视化,拖拽生成H5系统的更多相关文章
- 基于 Vue.js 之 iView UI 框架非工程化实践记要 使用 Newtonsoft.Json 操作 JSON 字符串 基于.net core实现项目自动编译、并生成nuget包 webpack + vue 在dev和production模式下的小小区别 这样入门asp.net core 之 静态文件 这样入门asp.net core,如何
基于 Vue.js 之 iView UI 框架非工程化实践记要 像我们平日里做惯了 Java 或者 .NET 这种后端程序员,对于前端的认识还常常停留在 jQuery 时代,包括其插件在需要时就引 ...
- 基于Vue.js PC桌面端弹出框组件|vue自定义弹层组件|vue模态框
vue.js构建的轻量级PC网页端交互式弹层组件VLayer. 前段时间有分享过一个vue移动端弹窗组件,今天给大家分享一个最近开发的vue pc端弹出层组件. VLayer 一款集Alert.Dia ...
- 基于Vue JS, Webpack 以及Material Design的渐进式web应用 [Part 1]
基于Vue JS, Webpack 以及Material Design的渐进式web应用 [Part 1] 原文:基于Vue JS, Webpack 以及Material Design的渐进式web应 ...
- Vue. 之 Element dialog 拖拽
Vue. 之 Element dialog 拖拽 默认情况下,在使用Element的Dialog模块时,弹出框是不能移动的,且 一旦点击遮罩层区域,弹框就会消失. 解决方案: 1 在 utils 中新 ...
- 快速开发 HTML5 WebGL 的 3D 斜面拖拽生成模型
前言 3D 场景中的面不只有水平面这一个,空间是由无数个面组成的,所以我们有可能会在任意一个面上放置物体,而空间中的面如何确定呢?我们知道,空间中的面可以由一个点和一条法线组成.这个 Demo 左侧为 ...
- 基于vue.js的简单用户管理
功能描述:添加.修改.搜索过滤 效果图: <!DOCTYPE html> <html lang="en"> <head> <title&g ...
- Vue项目中使用基于Vue.js的移动组件库cube-ui
cube-ui 是滴滴公司的技术团队基于 Vue.js 实现的精致移动端组件库.很赞,基本场景是够用了,感谢开源!感谢默默奉献的你们. 刚爬完坑,就来总结啦!!希望对需要的朋友有小小的帮助. (一)创 ...
- wordpress用Elementor拖拽生成酷炫页面
很多朋友看到wordpress网站做得很高大上,想知道是怎么做到的,其实很简单,用Elementor就能拖拽生成酷炫页面,ytkah就直接上干货了. 1.安装Elementor,到wordpress后 ...
- 基于VUE.JS的移动端框架Mint UI
Mint UI GitHub:github.com/ElemeFE/mint 项目主页:mint-ui.github.io/# Demo:elemefe.github.io/mint- 文档:mint ...
- php和js实现文件拖拽上传
Dropzone.js实现文件拖拽上传 http://www.sucaihuo.com/php/1399.html demo http://www.sucaihuo.com/jquery/13/139 ...
随机推荐
- Django——form组件的全局钩子
前面提到过的都是针对单个字段的校验,如果想同时对多个字段进行校验,就可以使用全局钩子(编写全局钩子预留的clean方法,可以获取到多个字段并进行校验) 注意: ---- 默认的校验.自定义正则规则的校 ...
- 用 AI 速读海量文档!5款 AI 阅读工具推荐
在当今信息爆炸的时代,我们在手动搜集和处理信息时面临着几个挑战: 浩如烟海的信息量远远超出了我们的阅读能力. 信息的复杂性要求我们重复筛选和过滤. 专业或难以理解的内容需要被翻译成易懂的语言. 需要从 ...
- nginx优化实践与验证
nginx优化实践 实践场景1: 单台nginx 2核4G 实践场景2: 三台nginx 2核4G 压测工具:WRK 初始安装的nginx压测: yum install -y nginx 安装WRK压 ...
- react props进阶 children属性
children属性,表示组件标签的子节点,当组件标签有子节点时,props就会有该属性,与与普通的props一样,其值可以使任意类型. # 父组件 class App extends React.C ...
- ASPNET Core Docker 运行慢报错 C:\Users\<username>\vsdbg\vs2017u5”无效
ASPNET Core Docker 运行慢报错 C:\Users\<username>\vsdbg\vs2017u5"无效 16.9.20122.2 1.迅雷下载: https ...
- vm ware 虚拟WIN XP 时卡
主机是I7 9700,SN750 NVME 1T SSD, 32G 内存,VM WARE 14,理论上虚拟WIN XP 不会卡,但实际情况就是很卡. 虚拟WIN7 ,WIN 10,UBUNTU LIN ...
- vue动态页签
效果图 前端 1 <template> 2 <!-- 总体情况 - 总览echarts --> 3 4 <div v-loading="loading" ...
- 手写LRU热点缓存数据结构
引言 LRU是开发过程中设计缓存的常用算法,在此基础上,如何设计一个高效的缓存呢?本文就带大家分析并手撸一个LRUCache. LRU算法 LRU(Least recently used,最近最少使用 ...
- AES加密和解密,key需要32位
AES加密和解密,key需要32位 package com.example.core.mydemo.sign; import org.apache.commons.codec.binary.Base6 ...
- BST-splay板子 - 维护一个分裂和合并的序列
splay 均摊复杂度 \(O(\log n)\) 证明: https://www.cnblogs.com/Mr-Spade/p/9715203.html 我这个 splay 有两个哨兵节点,分别是1 ...