logo

X6

  • 文档
  • API
  • 图表示例
  • 常见问题
  • 更新日志
  • XFlow
  • 所有产品antv logo arrow
  • 2.x
  • 简介
  • 快速上手
  • 基础
    • 画布
    • 节点
    • 边
    • 连接桩
    • 交互
    • 事件
    • 数据
  • 进阶
    • 连接点
    • 工具
    • 群组
    • React 节点
    • Vue 节点
    • Angular 节点
    • HTML 节点
  • 插件
    • 图形变换
    • 对齐线
    • 复制粘贴
    • 快捷键
    • 撤销重做
    • 框选
    • 滚动画布
    • 小地图
    • Dnd
    • Stencil
    • 导出
  • 升级到 2.x 版本
  • 开发者工具

复制粘贴

上一篇
对齐线
下一篇
快捷键

Resources

Ant Design
Galacea Effects
Umi-React 应用开发框架
Dumi-组件/文档研发工具
ahooks-React Hooks 库

社区

体验科技专栏
seeconfSEE Conf-蚂蚁体验科技大会

帮助

GitHub
StackOverflow

more products更多产品

Ant DesignAnt Design-企业级 UI 设计语言
yuque语雀-知识创作与分享工具
EggEgg-企业级 Node 开发框架
kitchenKitchen-Sketch 工具集
GalaceanGalacean-互动图形解决方案
xtech蚂蚁体验科技
© Copyright 2025 Ant Group Co., Ltd..备案号:京ICP备15032932号-38

Loading...

在本章节中主要介绍剪切板相关的知识,通过阅读,你可以了解到

  • 如何使用复制粘贴功能

使用

剪切板用于复制/粘贴节点和边,我们提供了一个独立的插件包 @antv/x6-plugin-clipboard 来使用这个功能。

# npm
$ npm install @antv/x6-plugin-clipboard --save
# yarn
$ yarn add @antv/x6-plugin-clipboard

然后我们在代码中这样使用:

import { Clipboard } from '@antv/x6-plugin-clipboard'
const graph = new Graph({
background: {
color: '#F2F7FA',
},
})
graph.use(
new Clipboard({
enabled: true,
}),
)

演示

  • 选中节点后,点击复制按钮复制节点。
  • 设置不同的 offset,观察粘贴时对节点位置的影响。
  • 启用 localStorage 后复制节点,刷新页面或重新打开浏览器后,点击粘贴按钮。
Clipboard Settings
Paste Offset
30

配置

属性名类型默认值必选描述
useLocalStoragebooleanfalse开启后被复制的节点/边同时被保存到 localStorage 中,浏览器刷新或者关闭后重新打开,复制/粘贴也能正常工作

API

graph.copy(...)

copy(cells: Cell[], options: CopyOptions = {}): this

复制节点/边。参数如下:

名称类型必选默认值描述
cellsCell[]✓被复制的节点/边。
options.deepboolean-是否递归复制所有子节点/边。
options.useLocalStorageboolean-是否将复制的节点/边保存在 localStorage 中。

graph.cut(...)

cut(cells: Cell[], options: CopyOptions = {}): this

剪切节点/边。参数如下:

名称类型必选默认值描述
cellsCell[]✓被剪切的节点/边。
options.deepboolean-是否递归复制所有子节点/边。
options.useLocalStorageboolean-是否将复制的节点/边保存在 localStorage 中。

graph.paste(...)

paste(options?: PasteOptions, graph?: Graph): Cell[]

粘贴,返回粘贴到画布的节点/边。参数如下:

名称类型必选默认值描述
options.useLocalStorageboolean-是否使用 localStorage 中的节点/边。
options.offsetnumber | { dx: number; dy: number }20粘贴到画布的节点/边的偏移量。
options.nodePropsNode.Properties-粘贴到画布的节点的额外属性。
options.edgePropsEdge.Properties-粘贴到画布的边的额外属性。
graphGraphthis粘贴的目标画布,默认粘贴到当前画布。

graph.getCellsInClipboard()

getCellsInClipboard: Cell[]

获取剪切板中的节点/边。

graph.cleanClipboard()

cleanClipboard(): this

清空剪切板。

graph.isClipboardEmpty()

isClipboardEmpty(): boolean

返回剪切板是否为空。

graph.isClipboardEnabled()

isClipboardEnabled(): boolean

返回是否启用了剪切板。

graph.enableClipboard()

enableClipboard(): this

启用剪切板。

graph.disableClipboard()

disableClipboard(): this

禁用剪切板。

graph.toggleClipboard(...)

toggleClipboard(enabled?: boolean): this

切换剪切板的启用状态。参数如下:

名称类型必选默认值描述
enabledboolean-是否启用剪切板,缺省时切换剪切板的启用状态。

事件

事件名称参数类型描述
clipboard:changed{ cells: Cell[] }复制、剪切、清空剪切板时触发
graph.on('clipboard:changed', ({ cells }) => {
console.log(cells)
})
// 我们也可以在插件实例上监听事件
clipboard.on('clipboard:changed', ({ cells }) => {
console.log(cells)
})