1.0.31 • Published 5 years ago

vue-matchup v1.0.31

Weekly downloads
3
License
MIT
Repository
github
Last release
5 years ago

vue-matchup

  • canves实现的列表/表格关系动态匹配组件

坐标计算用 getBoundingClientRect,动画效果会影响线展示位置,如: 使用element弹窗加载组件 vue-matchup 时,在动画结束前就已经算出个点相对窗口的坐标点,所以坐标值是有偏差的。解决办法是使用一个没有位移动画的弹窗加载组件。

演示

github pages

npm 安装

npm i vue-matchup -S

使用

import VueMatchup from 'vue-matchup'

Vue.use(VueMatchup)

基本使用

<template>
  <vue-matchup
    v-model="lines"
    :leftData="leftData"
    :rightData="rightData"
    :leftThead="leftThead"
    :rightThead="rightThead"
  >
  </vue-matchup>
</template>
<script>
export default {
  data () {
    return {
      lines: [
        { leftId: "L1-1", rightId: "R1-5" },
        { leftId: "L1-3", rightId: "R1-2" }
      ],
      leftData: [
        {
          lineNo: 0,
          qty: 100,
          unit: "PCS",
          nw: { weight: 100, unit: "KG" },
          gw: { weight: 120, unit: "KG" }
        }
      ],
      rightData: [
        {
          lineNo: 1,
          qty: 100,
          unit: "KG"
        }
      ],
      leftThead: [
        {
          title: "序号",
          props: "lineNo"
        },
        {
          title: "净重",
          props: "nw/weight" // table需要展示的数据,嵌套对象结构用'/'分隔
        }
      ],
      rightThead: [
        {
          title: "序号",
          props: "lineNo"
        },
        {
          title: "数量",
          props: "qty"
        }
      ]
    }
  }
}
</script>

Attributes

参数说明类型可选值默认值
lines已连接线的数组array-[]
leftData左面板展示的数据array-[]
rightData右面板展示的数据array-[]
leftThead左面板数据的标题及展示的字段{title: 'title', props: 'props'}string/array-[]
rightThead右面板数据的标题及展示的字段{title: 'title', props: 'props'}string/array-[]
leftTitle左面板折叠面板的标题,单个面板为string,多个面板为array 'title','title'string/array-left
rightTitle右面板折叠面板的标题,单个面板为string,多个面板为array 'title','title'string/array-right
leftIdFun自定义左面板row的id,此id用于行操作,及定义线条leftId与rightId,例 (row, index) => leftId:${index}-${row.lineNo},第一个回调参数为行数据,第二个回调参数为行号,leftIdFun不存在则使用默认idfunction--
rightIdFun自定义右面板row的id,此id用于行操作,及定义线条leftId与rightId,例 (row, index) => rightId:${index}-${row.lineNo},第一个回调参数为行数据,第二个回调参数为行号,leftIdFun不存在则使用默认idfunction--
collapseMaxHeight用于设置面板最大高度number--
collapseAccordion折叠面板是否开启手风琴模式(只展开一个面板)boolean-false
popover移入行时是否使用 popover 展示行详细内容boolean-false
popoverEnterablepopover 是否可移入boolean-false
popoverHideDelaypopover 显示隐藏的延时,popoverEnterable为true时可用number-200

行id

左右面板默认使用多层结构,默认id格式为 面板选项卡-行号,即 L1-1、R1-2,L2-1、R2-2的格式。

自定义行id使用leftIdFun、rightIdFun属性。

Methods

方法名说明参数
link连接线的方法{leftIds, rightIds, color}
drawLine重绘线-
leftCheckRow左面板选中行的方法,参数为row的idid
rightCheckRow右面板选中行的方法,参数为row的idid
clearChecked全局清空选中面板-
checkLines选中线的方法,参数为要选中线条id组成的数组array
unCheckedLines用于取消线的选中状态的方法,参数为要清除线条id组成的数组array
clearCheckedLines用于清空选中线的方法-

线的连接可以自定义,控制lines的增删来控制线,由于vue2.0还不能监听数组变化,因此需要用push,splice等方法操作数组。

Events

事件名说明回调参数
checkRow选中行时触发该事件id
unCheckRow取消选中行时触发该事件id
checkLine选中线时触发该事件id
unCheckLine取消选中线时触发该事件id
leftCheckChange左面板选中行时触发该事件array
rightCheckChange右面板选中行时触发该事件array
delete删除线条时触发该事件id

版本

1.0.31

  • 滚动增加debounce、线重绘增加throttle,优化组件性能。

1.0.30

  • 解决多线条选中,背景高亮显示不正确的问题。

1.0.29

  • 整合解决滚动导致偏移的问题。

1.0.28

  • 迁移rollup。

  • 线条选中时,线对应的 table 行背景高亮。

历史版本

1.0.31

5 years ago

1.0.30

5 years ago

1.0.29

5 years ago

1.0.28

5 years ago

1.0.27

5 years ago

1.0.26

5 years ago

1.0.25

5 years ago

1.0.24

5 years ago

1.0.23

5 years ago

1.0.22

5 years ago

1.0.21

5 years ago

1.0.20

5 years ago

1.0.19

5 years ago

1.0.18

5 years ago

1.0.17

5 years ago

1.0.16

5 years ago

1.0.15

5 years ago

1.0.14

5 years ago

1.0.13

5 years ago

1.0.12

5 years ago

1.0.11

5 years ago

1.0.1

5 years ago

1.0.0

5 years ago