zoukankan      html  css  js  c++  java
  • vue可调整大小和可拖动的组件vuedraggableresizable

    vue-draggable-resizable

    用于可调整大小和可拖动元素的组件、并支持组件之间的冲突检测和组件对齐。

    使用流程:

    安装依赖:

    npm install --save vue-draggable-resizable

    注册组件(在main.js中添加下列代码):

    import Vue from 'vue'
    import VueDraggableResizable from 'vue-draggable-resizable'
    Vue.component('vue-draggable-resizable', VueDraggableResizable)

    也可以在单个文件中使用该组件:

    <template>
      <div style="height: 500px;  500px; border: 1px solid red; position: relative;">
        <vue-draggable-resizable :w="100" :h="100" v-on:dragging="onDrag" v-on:resizing="onResize" :parent="true">
          <p>你可以进行拖拽和移动<br>
          X坐标为: {{ x }};Y坐标为: {{ y }} <br> 宽为: {{ width }} ;高为: {{ height }}</p>
        </vue-draggable-resizable>
      </div>
    </template>
    
    <script>
    import VueDraggableResizable from 'vue-draggable-resizable'
    
    export default {
      data: function () {
        return {
           0,
          height: 0,
          x: 0,
          y: 0
        }
      },
      methods: {
        onResize: function (x, y, width, height) {
          this.x = x
          this.y = y
          this.width = width
          this.height = height
        },
        onDrag: function (x, y) {
          this.x = x
          this.y = y
        }
      }
    }
    </script>

    Props

    isConflictCheck

    Type: Boolean
    Required: false
    Default: false

    定义组件是否开启冲突检测。

    <vue-draggable-resizable :is-conflict-check="true">
    snap

    Type: Boolean
    Required: false
    Default: false

    定义组件是否开启元素对齐。

    <vue-draggable-resizable :snap="true">
    snapTolerance

    Type: Number
    Required: false
    Default: 5

    当调用snap时,定义组件与元素之间的对齐距离,以像素为单位。

    <vue-draggable-resizable :snap="true" :snap-tolerance="20">
    active

    Type: Boolean
    Required: false
    Default: false

    确定组件是否应处于活动状态。 prop对更改做出反应,也可以与syncmodifier 一起使用以保持状态与父级同步。

    <vue-draggable-resizable :active="true">
    draggable

    Type: Boolean
    Required: false
    Default: true

    定义组件应该是否可拖动。

    <vue-draggable-resizable :draggable="false">
    resizable

    Type: Boolean
    Required: false
    Default: true

    定义组件是否可以调整大小。

    <vue-draggable-resizable :resizable="false">
    w

    Type: Number
    Required: false
    Default: 200

    定义元素的初始宽度。

    <vue-draggable-resizable :w="200">
    h

    Type: Number
    Required: false
    Default: 200

    定义元素的初始高度。

    <vue-draggable-resizable :h="200">
    minw

    Type: Number
    Required: false
    Default: 50

    定义元素的最小宽度。

    <vue-draggable-resizable :minw="50">
    minh

    Type: Number
    Required: false
    Default: 50

    定义元素的最小高度。

    <vue-draggable-resizable :minh="50">
    x

    Type: Number
    Required: false
    Default: 0

    定义元素的初始x位置。

    <vue-draggable-resizable :x="0">
    y

    Type: Number
    Required: false
    Default: 0

    定义元素的初始y位置。

    <vue-draggable-resizable :y="0">
    z

    Type: Number|String
    Required: false
    Default: auto

    定义元素的zIndex。

    <vue-draggable-resizable :z="999">
    handles

    Type: Array
    Required: false
    Default: ['tl', 'tm', 'tr', 'mr', 'br', 'bm', 'bl', 'ml']

    定义句柄数组以限制元素大小调整:

    • tl - 左上角
    • tm - 中上方
    • tr - 右上角
    • mr - 右中方
    • br - 右下角
    • bm - 下中方
    • bl - 左下方
    • ml - 左中方
    <vue-draggable-resizable :handles="['tm','bm','ml','mr']">
    axis

    Type: String
    Required: false
    Default: both

    定义元素可拖动的轴。可用值为x, y 或者 both.

    <vue-draggable-resizable axis="x">
    grid

    Type: Array
    Required: false
    Default: [1,1]

    定义捕捉元素的网格。

    <vue-draggable-resizable :grid="[1,1]">
    parent

    Type: Boolean
    Required: false
    Default: false

    将元素的移动和尺寸限制为父元素。

    <vue-draggable-resizable :parent="true">
    dragHandle

    Type: String
    Required: false

    定义应该用于拖动组件的选择器。

    <vue-draggable-resizable drag-handle=".drag">
    dragCancel

    Type: String
    Required: false

    定义应该用于阻止拖动初始化的选择器。

    <vue-draggable-resizable drag-cancel=".drag">
    maximize

    Type: Boolean
    Required: false
    Default: false

    如果设置为true,则允许组件在双击时填充其父级。

    <vue-draggable-resizable :maximize="true">

    Events

    activated

    Required: false
    Parameters: -

    单击组件时调用,以显示句柄。

    <vue-draggable-resizable @activated="onActivated">
    deactivated

    Required: false
    Parameters: -

    每当用户单击组件外的任何位置时调用,以便停用它。

    <vue-draggable-resizable @deactivated="onDeactivated">
    resizing

    Required: false
    Parameters:

    • left元素的X位置
    • top 元素的Y位置
    • width元素的宽度
    • height 元素的高度

    每当组件调整大小时调用。

    <vue-draggable-resizable @resizing="onResizing">
    resizestop

    Required: false
    Parameters:

    • left 元素的X位置
    • top 元素的Y位置
    • width 元素的宽度
    • height 元素的高度

    每当组件停止调整大小时调用。

    <vue-draggable-resizable @resizestop="onResizstop">
    dragging

    Required: false
    Parameters:

    • left 元素的X位置
    • top 元素的Y位置

    每当拖动组件时调用。

    <vue-draggable-resizable @dragging="onDragging">
    dragstop

    Required: false
    Parameters:

    • left元素的X位置
    • top 元素的Y位置

    每当组件停止拖动时调用。

    <vue-draggable-resizable @dragstop="onDragstop">
  • 相关阅读:
    JetBrains Rider 在 Mac 环境下将 cs 文件生成 exe
    Unity3d 控制物体移动、旋转、缩放
    Unity3d 脚本使用规则
    Unity3D 脚本模板修改方法
    Intelli IDEA 设置项目编码(Mac)
    搭建LayaBox的生产环境,并helloWorld
    unity Lighting
    流畅度测试
    Failure [INSTALL_FAILED_USER_RESTRICTED: Install canceled by user]
    Unity GUI(uGUI)使用心得与性能总结
  • 原文地址:https://www.cnblogs.com/cupid10/p/15617601.html
Copyright © 2011-2022 走看看