效果预览

功能简介

基于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系统的更多相关文章

  1. 基于 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 时代,包括其插件在需要时就引 ...

  2. 基于Vue.js PC桌面端弹出框组件|vue自定义弹层组件|vue模态框

    vue.js构建的轻量级PC网页端交互式弹层组件VLayer. 前段时间有分享过一个vue移动端弹窗组件,今天给大家分享一个最近开发的vue pc端弹出层组件. VLayer 一款集Alert.Dia ...

  3. 基于Vue JS, Webpack 以及Material Design的渐进式web应用 [Part 1]

    基于Vue JS, Webpack 以及Material Design的渐进式web应用 [Part 1] 原文:基于Vue JS, Webpack 以及Material Design的渐进式web应 ...

  4. Vue. 之 Element dialog 拖拽

    Vue. 之 Element dialog 拖拽 默认情况下,在使用Element的Dialog模块时,弹出框是不能移动的,且 一旦点击遮罩层区域,弹框就会消失. 解决方案: 1 在 utils 中新 ...

  5. 快速开发 HTML5 WebGL 的 3D 斜面拖拽生成模型

    前言 3D 场景中的面不只有水平面这一个,空间是由无数个面组成的,所以我们有可能会在任意一个面上放置物体,而空间中的面如何确定呢?我们知道,空间中的面可以由一个点和一条法线组成.这个 Demo 左侧为 ...

  6. 基于vue.js的简单用户管理

    功能描述:添加.修改.搜索过滤 效果图: <!DOCTYPE html> <html lang="en"> <head> <title&g ...

  7. Vue项目中使用基于Vue.js的移动组件库cube-ui

    cube-ui 是滴滴公司的技术团队基于 Vue.js 实现的精致移动端组件库.很赞,基本场景是够用了,感谢开源!感谢默默奉献的你们. 刚爬完坑,就来总结啦!!希望对需要的朋友有小小的帮助. (一)创 ...

  8. wordpress用Elementor拖拽生成酷炫页面

    很多朋友看到wordpress网站做得很高大上,想知道是怎么做到的,其实很简单,用Elementor就能拖拽生成酷炫页面,ytkah就直接上干货了. 1.安装Elementor,到wordpress后 ...

  9. 基于VUE.JS的移动端框架Mint UI

    Mint UI GitHub:github.com/ElemeFE/mint 项目主页:mint-ui.github.io/# Demo:elemefe.github.io/mint- 文档:mint ...

  10. php和js实现文件拖拽上传

    Dropzone.js实现文件拖拽上传 http://www.sucaihuo.com/php/1399.html demo http://www.sucaihuo.com/jquery/13/139 ...

随机推荐

  1. TS码流解析(二)PSI PAT PMT

    TS码流有PSI和PES两种负载,这一节主要来了解PSI是如何解析的. 1.PSI PSI(Program Specific Information)节目专用信息,用来描述TS码流的节目组成等信息.P ...

  2. Flutter学习网站和安装问题

    一.Flutter网站 Flutter中文开发者网站(推荐) https://flutter.cn/ 二.Flutter第三方库 Pub.Dev https://pub.dev/ 三.Flutter源 ...

  3. 直播相关-搭建直播流服务器nodejs

    一.安装nodejs环境 去nodejs官方网站下载安装包 https://nodejs.org/en/#download 安装完成之后测试: LUNLI-MC1:~ lunli$ node -v v ...

  4. Python实现字符串模糊匹配

      在一个字符串中,有时需对其中某些内容进行模糊匹配以实现条件的判定,如在"你好,hello,world"中判断是否含有"llo".Python中通过re.se ...

  5. else if

      // if(){}else if(){}...else{}         // 多种条件,多种情况下的判断语句         // 必须要注意         // 1,else if 之后有 ...

  6. Nodejs概述 安装Nodejs os模块 path模块 url模块 querystring模块

    一.Nodejs概述 介绍 相关网址: https://nodejs.org/zh-cn/ http://nodejs.cn/ Node.js 是一个开源与跨平台的JavaScript 运行时环境.它 ...

  7. git创建分支 解决git网速太慢

                所谓的分支,就是每个人负责的不同的模块             整个项目有一个主干 master             所有的分支都是 从主干 maser 上 分支而来的   ...

  8. 在MySQL中INNER JOIN、LEFT JOIN、RIGHT JOIN 和 FULL JOIN 有什么区别?

    我们有两张表: TableA:id  firstName                  lastName.......................................1   aru ...

  9. ConvertLatOrLonFilter-经纬度格式转换-保留6位

    ConvertLatOrLonFilter-经纬度格式转换-保留6位 /** * 转换经纬度 * 小数点最后最多为6位 * @param latOrLon * @return */ private S ...

  10. 新浪微博动态 RSA 分析图文+登录

    Tips:当你看到这个提示的时候,说明当前的文章是由原emlog博客系统搬迁至此的,文章发布时间已过于久远,编排和内容不一定完整,还请谅解` 新浪微博动态 RSA 分析图文+登录 日期:2016-10 ...