支持展开到指定层级
This commit is contained in:
parent
5d4cf8a3c3
commit
471bd3c5e5
364
README.md
364
README.md
@ -82,6 +82,7 @@ npm run buildLibrary
|
|||||||
cd web
|
cd web
|
||||||
npm run build
|
npm run build
|
||||||
```
|
```
|
||||||
|
|
||||||
会自动把`index.html`移动到根目录。
|
会自动把`index.html`移动到根目录。
|
||||||
|
|
||||||
## 相关文章
|
## 相关文章
|
||||||
@ -98,15 +99,15 @@ npm i simple-mind-map
|
|||||||
|
|
||||||
`0.2.0`版本之前的注意事项:
|
`0.2.0`版本之前的注意事项:
|
||||||
|
|
||||||
>注意:本项目为源码直接发布,并未进行打包,如果出现编译失败的情况,Vue CLI创建的项目可以在vue.config.js文件中增加如下配置来让babel-loader编译本依赖:
|
> 注意:本项目为源码直接发布,并未进行打包,如果出现编译失败的情况,Vue CLI创建的项目可以在vue.config.js文件中增加如下配置来让babel-loader编译本依赖:
|
||||||
>
|
>
|
||||||
>```js
|
> ```js
|
||||||
>module.exports = {
|
> module.exports = {
|
||||||
> transpileDependencies: ['simple-mind-map']
|
> transpileDependencies: ['simple-mind-map']
|
||||||
>}
|
> }
|
||||||
>```
|
> ```
|
||||||
>
|
>
|
||||||
>其他项目请自行修改打包配置。
|
> 其他项目请自行修改打包配置。
|
||||||
|
|
||||||
# API
|
# API
|
||||||
|
|
||||||
@ -161,23 +162,22 @@ v0.2.8+
|
|||||||
|
|
||||||
### 实例化选项:
|
### 实例化选项:
|
||||||
|
|
||||||
| 字段名称 | 类型 | 默认值 | 描述 | 是否必填 |
|
| 字段名称 | 类型 | 默认值 | 描述 | 是否必填 |
|
||||||
| -------------------- | ------- | ---------------- | ------------------------------------------------------------ | -------- |
|
| ------------------------------ | ------- | ---------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---- |
|
||||||
| el | Element | | 容器元素,必须为DOM元素 | 是 |
|
| el | Element | | 容器元素,必须为DOM元素 | 是 |
|
||||||
| data | Object | {} | 思维导图数据,可参考:[https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/example/exampleData.js](https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/example/exampleData.js) | |
|
| data | Object | {} | 思维导图数据,可参考:[https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/example/exampleData.js](https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/example/exampleData.js) | |
|
||||||
| layout | String | logicalStructure | 布局类型,可选列表:logicalStructure(逻辑结构图)、mindMap(思维导图)、catalogOrganization(目录组织图)、organizationStructure(组织结构图) | |
|
| layout | String | logicalStructure | 布局类型,可选列表:logicalStructure(逻辑结构图)、mindMap(思维导图)、catalogOrganization(目录组织图)、organizationStructure(组织结构图) | |
|
||||||
| theme | String | default | 主题,可选列表:default(默认)、classic(脑图经典)、minions(小黄人)、pinkGrape(粉红葡萄)、mint(薄荷)、gold(金色vip)、vitalityOrange(活力橙)、greenLeaf(绿叶)、dark2(暗色2)、skyGreen(天清绿)、classic2(脑图经典2)、classic3(脑图经典3)、classic4(脑图经典4,v0.2.0+)、classicGreen(经典绿)、classicBlue(经典蓝)、blueSky(天空蓝)、brainImpairedPink(脑残粉)、dark(暗色)、earthYellow(泥土黄)、freshGreen(清新绿)、freshRed(清新红)、romanticPurple(浪漫紫) | |
|
| theme | String | default | 主题,可选列表:default(默认)、classic(脑图经典)、minions(小黄人)、pinkGrape(粉红葡萄)、mint(薄荷)、gold(金色vip)、vitalityOrange(活力橙)、greenLeaf(绿叶)、dark2(暗色2)、skyGreen(天清绿)、classic2(脑图经典2)、classic3(脑图经典3)、classic4(脑图经典4,v0.2.0+)、classicGreen(经典绿)、classicBlue(经典蓝)、blueSky(天空蓝)、brainImpairedPink(脑残粉)、dark(暗色)、earthYellow(泥土黄)、freshGreen(清新绿)、freshRed(清新红)、romanticPurple(浪漫紫) | |
|
||||||
| themeConfig | Object | {} | 主题配置,会和所选择的主题进行合并,可用字段可参考:[https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/src/themes/default.js](https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/src/themes/default.js) | |
|
| themeConfig | Object | {} | 主题配置,会和所选择的主题进行合并,可用字段可参考:[https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/src/themes/default.js](https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/src/themes/default.js) | |
|
||||||
| scaleRatio | Number | 0.1 | 放大缩小的增量比例 | |
|
| scaleRatio | Number | 0.1 | 放大缩小的增量比例 | |
|
||||||
| maxTag | Number | 5 | 节点里最多显示的标签数量,多余的会被丢弃 | |
|
| maxTag | Number | 5 | 节点里最多显示的标签数量,多余的会被丢弃 | |
|
||||||
| exportPadding | Number | 20 | 导出图片时的内边距 | |
|
| exportPadding | Number | 20 | 导出图片时的内边距 | |
|
||||||
| imgTextMargin | Number | 5 | 节点里图片和文字的间距 | |
|
| imgTextMargin | Number | 5 | 节点里图片和文字的间距 | |
|
||||||
| textContentMargin | Number | 2 | 节点里各种文字信息的间距,如图标和文字的间距 | |
|
| textContentMargin | Number | 2 | 节点里各种文字信息的间距,如图标和文字的间距 | |
|
||||||
| selectTranslateStep | Number | 3 | 多选节点时鼠标移动到边缘时的画布移动偏移量 | |
|
| selectTranslateStep | Number | 3 | 多选节点时鼠标移动到边缘时的画布移动偏移量 | |
|
||||||
| selectTranslateLimit | Number | 20 | 多选节点时鼠标移动距边缘多少距离时开始偏移 | |
|
| selectTranslateLimit | Number | 20 | 多选节点时鼠标移动距边缘多少距离时开始偏移 | |
|
||||||
| customNoteContentShow(v0.1.6+) | Object | null | 自定义节点备注内容显示,Object类型,结构为:{show: (noteContent, left, top) => {// 你的显示节点备注逻辑 }, hide: () => {// 你的隐藏节点备注逻辑 }} | |
|
| customNoteContentShow(v0.1.6+) | Object | null | 自定义节点备注内容显示,Object类型,结构为:{show: (noteContent, left, top) => {// 你的显示节点备注逻辑 }, hide: () => {// 你的隐藏节点备注逻辑 }} | |
|
||||||
| readonly(v0.1.7+) | Boolean | false | 是否是只读模式 | |
|
| readonly(v0.1.7+) | Boolean | false | 是否是只读模式 | |
|
||||||
|
|
||||||
|
|
||||||
### 实例方法:
|
### 实例方法:
|
||||||
|
|
||||||
@ -185,14 +185,10 @@ v0.2.8+
|
|||||||
|
|
||||||
触发整体渲染,会进行节点复用,性能较`reRender`会更好一点,如果只是节点位置变化了可以调用该方法进行渲染
|
触发整体渲染,会进行节点复用,性能较`reRender`会更好一点,如果只是节点位置变化了可以调用该方法进行渲染
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### reRender()
|
#### reRender()
|
||||||
|
|
||||||
整体重新渲染,会清空画布,节点也会重新创建,性能不好,慎重使用
|
整体重新渲染,会清空画布,节点也会重新创建,性能不好,慎重使用
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### resize()
|
#### resize()
|
||||||
|
|
||||||
容器尺寸变化后,需要调用该方法进行适应
|
容器尺寸变化后,需要调用该方法进行适应
|
||||||
@ -207,57 +203,47 @@ v0.1.7+。切换模式为只读或编辑。
|
|||||||
|
|
||||||
监听事件,事件列表:
|
监听事件,事件列表:
|
||||||
|
|
||||||
| 事件名称 | 描述 | 回调参数 |
|
| 事件名称 | 描述 | 回调参数 |
|
||||||
| --------------------------- | ------------------------------------------ | ------------------------------------------------------------ |
|
| ------------------------- | --------------------- | ----------------------------------------------------- |
|
||||||
| data_change | 渲染树数据变化,可以监听该方法获取最新数据 | data(当前渲染树数据) |
|
| data_change | 渲染树数据变化,可以监听该方法获取最新数据 | data(当前渲染树数据) |
|
||||||
| view_data_change(v0.1.1+) | 视图变化数据,比如拖动或缩放时会触发 | data(当前视图状态数据) |
|
| view_data_change(v0.1.1+) | 视图变化数据,比如拖动或缩放时会触发 | data(当前视图状态数据) |
|
||||||
| back_forward | 前进或回退 | activeHistoryIndex(当前在历史数据数组里的索引)、length(当前历史数据数组的长度) |
|
| back_forward | 前进或回退 | activeHistoryIndex(当前在历史数据数组里的索引)、length(当前历史数据数组的长度) |
|
||||||
| draw_click | *画布的单击事件* | e(事件对象) |
|
| draw_click | *画布的单击事件* | e(事件对象) |
|
||||||
| svg_mousedown | svg画布的鼠标按下事件 | e(事件对象) |
|
| svg_mousedown | svg画布的鼠标按下事件 | e(事件对象) |
|
||||||
| mousedown | el元素的鼠标按下事件 | e(事件对象)、this(Event事件类实例) |
|
| mousedown | el元素的鼠标按下事件 | e(事件对象)、this(Event事件类实例) |
|
||||||
| mousemove | el元素的鼠标移动事件 | e(事件对象)、this(Event事件类实例) |
|
| mousemove | el元素的鼠标移动事件 | e(事件对象)、this(Event事件类实例) |
|
||||||
| drag | 如果是按住左键拖动的话会触发拖动事件 | e(事件对象)、this(Event事件类实例) |
|
| drag | 如果是按住左键拖动的话会触发拖动事件 | e(事件对象)、this(Event事件类实例) |
|
||||||
| mouseup | el元素的鼠标松开事件 | e(事件对象)、this(Event事件类实例) |
|
| mouseup | el元素的鼠标松开事件 | e(事件对象)、this(Event事件类实例) |
|
||||||
| mousewheel | 鼠标滚动事件 | e(事件对象)、dir(向上up还是向下down滚动)、this(Event事件类实例) |
|
| mousewheel | 鼠标滚动事件 | e(事件对象)、dir(向上up还是向下down滚动)、this(Event事件类实例) |
|
||||||
| contextmenu | svg画布的鼠标右键菜单事件 | e(事件对象) |
|
| contextmenu | svg画布的鼠标右键菜单事件 | e(事件对象) |
|
||||||
| node_click | 节点的单击事件 | this(节点实例)、e(事件对象) |
|
| node_click | 节点的单击事件 | this(节点实例)、e(事件对象) |
|
||||||
| node_mousedown | 节点的鼠标按下事件 | this(节点实例)、e(事件对象) |
|
| node_mousedown | 节点的鼠标按下事件 | this(节点实例)、e(事件对象) |
|
||||||
| node_mouseup | 节点的鼠标松开事件 | this(节点实例)、e(事件对象) |
|
| node_mouseup | 节点的鼠标松开事件 | this(节点实例)、e(事件对象) |
|
||||||
| node_dblclick | 节点的双击事件 | this(节点实例)、e(事件对象) |
|
| node_dblclick | 节点的双击事件 | this(节点实例)、e(事件对象) |
|
||||||
| node_contextmenu | 节点的右键菜单事件 | e(事件对象)、this(节点实例) |
|
| node_contextmenu | 节点的右键菜单事件 | e(事件对象)、this(节点实例) |
|
||||||
| before_node_active | 节点激活前事件 | this(节点实例)、activeNodeList(当前激活的所有节点列表) |
|
| before_node_active | 节点激活前事件 | this(节点实例)、activeNodeList(当前激活的所有节点列表) |
|
||||||
| node_active | 节点激活事件 | this(节点实例)、activeNodeList(当前激活的所有节点列表) |
|
| node_active | 节点激活事件 | this(节点实例)、activeNodeList(当前激活的所有节点列表) |
|
||||||
| expand_btn_click | 节点展开或收缩事件 | this(节点实例) |
|
| expand_btn_click | 节点展开或收缩事件 | this(节点实例) |
|
||||||
| before_show_text_edit | 节点文本编辑框即将打开事件 | |
|
| before_show_text_edit | 节点文本编辑框即将打开事件 | |
|
||||||
| hide_text_edit | 节点文本编辑框关闭事件 | textEditNode(文本编辑框DOM节点)、activeNodeList(当前激活的所有节点列表) |
|
| hide_text_edit | 节点文本编辑框关闭事件 | textEditNode(文本编辑框DOM节点)、activeNodeList(当前激活的所有节点列表) |
|
||||||
| scale | 放大缩小事件 | scale(缩放比例) |
|
| scale | 放大缩小事件 | scale(缩放比例) |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### emit(event, ...args)
|
#### emit(event, ...args)
|
||||||
|
|
||||||
触发事件,可以是上面表格里的事件,也可以是自定义事件
|
触发事件,可以是上面表格里的事件,也可以是自定义事件
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### off(event, fn)
|
#### off(event, fn)
|
||||||
|
|
||||||
解绑事件
|
解绑事件
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### setTheme(theme)
|
#### setTheme(theme)
|
||||||
|
|
||||||
切换主题,可选主题见上面的选项表格
|
切换主题,可选主题见上面的选项表格
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### getTheme()
|
#### getTheme()
|
||||||
|
|
||||||
获取当前主题
|
获取当前主题
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### setThemeConfig(config)
|
#### setThemeConfig(config)
|
||||||
|
|
||||||
设置主题配置,`config`同上面选项表格里的选项`themeConfig`
|
设置主题配置,`config`同上面选项表格里的选项`themeConfig`
|
||||||
@ -270,57 +256,53 @@ v0.1.7+。切换模式为只读或编辑。
|
|||||||
|
|
||||||
获取某个主题配置属性值
|
获取某个主题配置属性值
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### getLayout()
|
#### getLayout()
|
||||||
|
|
||||||
获取当前的布局结构
|
获取当前的布局结构
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### setLayout(layout)
|
#### setLayout(layout)
|
||||||
|
|
||||||
设置布局结构,可选值见上面选项表格的`layout`字段
|
设置布局结构,可选值见上面选项表格的`layout`字段
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### execCommand(name, ...args)
|
#### execCommand(name, ...args)
|
||||||
|
|
||||||
执行命令,每执行一个命令就会在历史堆栈里添加一条记录用于回退或前进。所有命令如下:
|
执行命令,每执行一个命令就会在历史堆栈里添加一条记录用于回退或前进。所有命令如下:
|
||||||
|
|
||||||
| 命令名称 | 描述 | 参数 |
|
| 命令名称 | 描述 | 参数 |
|
||||||
| ----------------------------------- | ------------------------------------------------------------ | ------------------------------------------------------------ |
|
| --------------------------------- | -------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
|
||||||
| SELECT_ALL | 全选 | |
|
| SELECT_ALL | 全选 | |
|
||||||
| BACK | 回退指定的步数 | step(要回退的步数,默认为1) |
|
| BACK | 回退指定的步数 | step(要回退的步数,默认为1) |
|
||||||
| FORWARD | 前进指定的步数 | step(要前进的步数,默认为1) |
|
| FORWARD | 前进指定的步数 | step(要前进的步数,默认为1) |
|
||||||
| INSERT_NODE | 插入同级节点,操作节点为当前激活的节点,如果有多个激活节点,只会对第一个有效 | |
|
| INSERT_NODE | 插入同级节点,操作节点为当前激活的节点,如果有多个激活节点,只会对第一个有效 | |
|
||||||
| INSERT_CHILD_NODE | 插入子节点,操作节点为当前激活的节点 | |
|
| INSERT_CHILD_NODE | 插入子节点,操作节点为当前激活的节点 | |
|
||||||
| UP_NODE | 上移节点,操作节点为当前激活的节点,如果有多个激活节点,只会对第一个有效,对根节点或在列表里的第一个节点使用无效 | |
|
| UP_NODE | 上移节点,操作节点为当前激活的节点,如果有多个激活节点,只会对第一个有效,对根节点或在列表里的第一个节点使用无效 | |
|
||||||
| DOWN_NODE | 操作节点为当前激活的节点,如果有多个激活节点,只会对第一个有效,对根节点或在列表里的最后一个节点使用无效 | |
|
| DOWN_NODE | 操作节点为当前激活的节点,如果有多个激活节点,只会对第一个有效,对根节点或在列表里的最后一个节点使用无效 | |
|
||||||
| REMOVE_NODE | 删除节点,操作节点为当前激活的节点 | |
|
| REMOVE_NODE | 删除节点,操作节点为当前激活的节点 | |
|
||||||
| PASTE_NODE | 粘贴节点到节点,操作节点为当前激活的节点 | data(要粘贴的节点数据,一般通过`renderer.copyNode()`方法和`renderer.cutNode()`方法获取) |
|
| PASTE_NODE | 粘贴节点到节点,操作节点为当前激活的节点 | data(要粘贴的节点数据,一般通过`renderer.copyNode()`方法和`renderer.cutNode()`方法获取) |
|
||||||
| CUT_NODE | 剪切节点,操作节点为当前激活的节点,如果有多个激活节点,只会对第一个有效,对根节点使用无效 | callback(回调函数,剪切的节点数据会通过调用该函数并通过参数返回) |
|
| CUT_NODE | 剪切节点,操作节点为当前激活的节点,如果有多个激活节点,只会对第一个有效,对根节点使用无效 | callback(回调函数,剪切的节点数据会通过调用该函数并通过参数返回) |
|
||||||
| SET_NODE_STYLE | 修改节点样式 | node(要设置样式的节点)、prop(样式属性)、value(样式属性值)、isActive(布尔值,是否设置的是激活状态的样式) |
|
| SET_NODE_STYLE | 修改节点样式 | node(要设置样式的节点)、prop(样式属性)、value(样式属性值)、isActive(布尔值,是否设置的是激活状态的样式) |
|
||||||
| SET_NODE_ACTIVE | 设置节点是否激活 | node(要设置的节点)、active(布尔值,是否激活) |
|
| SET_NODE_ACTIVE | 设置节点是否激活 | node(要设置的节点)、active(布尔值,是否激活) |
|
||||||
| CLEAR_ACTIVE_NODE | 清除当前已激活节点的激活状态,操作节点为当前激活的节点 | |
|
| CLEAR_ACTIVE_NODE | 清除当前已激活节点的激活状态,操作节点为当前激活的节点 | |
|
||||||
| SET_NODE_EXPAND | 设置节点是否展开 | node(要设置的节点)、expand(布尔值,是否展开) |
|
| SET_NODE_EXPAND | 设置节点是否展开 | node(要设置的节点)、expand(布尔值,是否展开) |
|
||||||
| EXPAND_ALL | 展开所有节点 | |
|
| EXPAND_ALL | 展开所有节点 | |
|
||||||
| UNEXPAND_ALL | 收起所有节点 | |
|
| UNEXPAND_ALL | 收起所有节点 | |
|
||||||
| SET_NODE_DATA | 更新节点数据,即更新节点数据对象里`data`对象的数据 | node(要设置的节点)、data(对象,要更新的数据,如`{expand: true}`) |
|
| UNEXPAND_TO_LEVEL(v0.2.8+) | 展开到指定层级 | level(要展开到的层级,1、2、3...) |
|
||||||
| SET_NODE_TEXT | 设置节点文本 | node(要设置的节点)、text(要设置的文本字符串,换行可以使用`\n`) |
|
| SET_NODE_DATA | 更新节点数据,即更新节点数据对象里`data`对象的数据 | node(要设置的节点)、data(对象,要更新的数据,如`{expand: true}`) |
|
||||||
| SET_NODE_IMAGE | 设置节点图片 | node(要设置的节点)、imgData(对象,图片信息,结构为:`{url, title, width, height}`,图片的宽高必须要传) |
|
| SET_NODE_TEXT | 设置节点文本 | node(要设置的节点)、text(要设置的文本字符串,换行可以使用`\n`) |
|
||||||
| SET_NODE_ICON | 设置节点图标 | node(要设置的节点)、icons(数组,预定义的图片名称组成的数组,可用图标可在[https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/src/svg/icons.js](https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/src/svg/icons.js)文件里的`nodeIconList`列表里获取到,图标名称为`type_name`,如`['priority_1']`) |
|
| SET_NODE_IMAGE | 设置节点图片 | node(要设置的节点)、imgData(对象,图片信息,结构为:`{url, title, width, height}`,图片的宽高必须要传) |
|
||||||
| SET_NODE_HYPERLINK | 设置节点超链接 | node(要设置的节点)、link(超链接地址)、title(超链接名称,可选) |
|
| SET_NODE_ICON | 设置节点图标 | node(要设置的节点)、icons(数组,预定义的图片名称组成的数组,可用图标可在[https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/src/svg/icons.js](https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/src/svg/icons.js)文件里的`nodeIconList`列表里获取到,图标名称为`type_name`,如`['priority_1']`) |
|
||||||
| SET_NODE_NOTE | 设置节点备注 | node(要设置的节点)、note(备注文字) |
|
| SET_NODE_HYPERLINK | 设置节点超链接 | node(要设置的节点)、link(超链接地址)、title(超链接名称,可选) |
|
||||||
| SET_NODE_TAG | 设置节点标签 | node(要设置的节点)、tag(字符串数组,内置颜色信息可在[https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/src/utils/constant.js](https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/src/utils/constant.js)里获取到) |
|
| SET_NODE_NOTE | 设置节点备注 | node(要设置的节点)、note(备注文字) |
|
||||||
| INSERT_AFTER(v0.1.5+) | 将节点移动到另一个节点的后面 | node(要移动的节点)、 exist(目标节点) |
|
| SET_NODE_TAG | 设置节点标签 | node(要设置的节点)、tag(字符串数组,内置颜色信息可在[https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/src/utils/constant.js](https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/src/utils/constant.js)里获取到) |
|
||||||
| INSERT_BEFORE(v0.1.5+) | 将节点移动到另一个节点的前面 | node(要移动的节点)、 exist(目标节点) |
|
| INSERT_AFTER(v0.1.5+) | 将节点移动到另一个节点的后面 | node(要移动的节点)、 exist(目标节点) |
|
||||||
| MOVE_NODE_TO(v0.1.5+) | 移动一个节点作为另一个节点的子节点 | node(要移动的节点)、 toNode(目标节点) |
|
| INSERT_BEFORE(v0.1.5+) | 将节点移动到另一个节点的前面 | node(要移动的节点)、 exist(目标节点) |
|
||||||
| ADD_GENERALIZATION(v0.2.0+) | 添加节点概要 | data(概要的数据,对象格式,节点的数字段都支持,默认为{text: '概要'}) |
|
| MOVE_NODE_TO(v0.1.5+) | 移动一个节点作为另一个节点的子节点 | node(要移动的节点)、 toNode(目标节点) |
|
||||||
| REMOVE_GENERALIZATION(v0.2.0+) | 删除节点概要 | |
|
| ADD_GENERALIZATION(v0.2.0+) | 添加节点概要 | data(概要的数据,对象格式,节点的数字段都支持,默认为{text: '概要'}) |
|
||||||
| SET_NODE_CUSTOM_POSITION(v0.2.0+) | 设置节点自定义位置 | node(要设置的节点)、 left(自定义的x坐标,默认为undefined)、 top(自定义的y坐标,默认为undefined) |
|
| REMOVE_GENERALIZATION(v0.2.0+) | 删除节点概要 | |
|
||||||
| RESET_LAYOUT(v0.2.0+) | 一键整理布局 | |
|
| SET_NODE_CUSTOM_POSITION(v0.2.0+) | 设置节点自定义位置 | node(要设置的节点)、 left(自定义的x坐标,默认为undefined)、 top(自定义的y坐标,默认为undefined) |
|
||||||
| SET_NODE_SHAPE(v0.2.4+) | 设置节点形状 | node(要设置的节点)、shape(形状,全部形状:https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/src/Shape.js) |
|
| RESET_LAYOUT(v0.2.0+) | 一键整理布局 | |
|
||||||
|
| SET_NODE_SHAPE(v0.2.4+) | 设置节点形状 | node(要设置的节点)、shape(形状,全部形状:https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/src/Shape.js) |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### setData(data)
|
#### setData(data)
|
||||||
@ -337,7 +319,6 @@ v0.2.7+
|
|||||||
|
|
||||||
`data`:完整数据,结构可参考[exportFullData](https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/example/exportFullData.json)
|
`data`:完整数据,结构可参考[exportFullData](https://github.com/wanglin2/mind-map/blob/main/simple-mind-map/example/exportFullData.json)
|
||||||
|
|
||||||
|
|
||||||
#### export(type, isDownload, fileName)
|
#### export(type, isDownload, fileName)
|
||||||
|
|
||||||
导出
|
导出
|
||||||
@ -358,22 +339,16 @@ v0.1.5+
|
|||||||
|
|
||||||
`render`实例负载整个渲染过程,可通过`mindMap.renderer`获取到
|
`render`实例负载整个渲染过程,可通过`mindMap.renderer`获取到
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
### 属性
|
### 属性
|
||||||
|
|
||||||
#### activeNodeList
|
#### activeNodeList
|
||||||
|
|
||||||
获取当前激活的节点列表
|
获取当前激活的节点列表
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### root
|
#### root
|
||||||
|
|
||||||
获取节点树的根节点
|
获取节点树的根节点
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
### 方法
|
### 方法
|
||||||
|
|
||||||
#### clearActive()
|
#### clearActive()
|
||||||
@ -396,74 +371,52 @@ v0.1.5+
|
|||||||
|
|
||||||
添加节点到激活列表里
|
添加节点到激活列表里
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### removeActiveNode(node)
|
#### removeActiveNode(node)
|
||||||
|
|
||||||
在激活列表里移除某个节点
|
在激活列表里移除某个节点
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### findActiveNodeIndex(node)
|
#### findActiveNodeIndex(node)
|
||||||
|
|
||||||
检索某个节点在激活列表里的索引
|
检索某个节点在激活列表里的索引
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### getNodeIndex(node)
|
#### getNodeIndex(node)
|
||||||
|
|
||||||
获取节点在同级里的位置索引
|
获取节点在同级里的位置索引
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### removeOneNode(node)
|
#### removeOneNode(node)
|
||||||
|
|
||||||
删除某个指定节点
|
删除某个指定节点
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### copyNode()
|
#### copyNode()
|
||||||
|
|
||||||
复制节点,操作节点为当前激活节点,有多个激活节点只会操作第一个节点
|
复制节点,操作节点为当前激活节点,有多个激活节点只会操作第一个节点
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### setNodeDataRender(node, data)
|
#### setNodeDataRender(node, data)
|
||||||
|
|
||||||
设置节点数据,即`data`字段的数据,并会根据节点大小是否变化来判断是否需要重新渲染该节点,`data`为对象,如:`{text: '我是新文本'}`
|
设置节点数据,即`data`字段的数据,并会根据节点大小是否变化来判断是否需要重新渲染该节点,`data`为对象,如:`{text: '我是新文本'}`
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### moveNodeTo(node, toNode)
|
#### moveNodeTo(node, toNode)
|
||||||
|
|
||||||
v0.1.5+
|
v0.1.5+
|
||||||
|
|
||||||
移动一个节点作为另一个节点的子节点
|
移动一个节点作为另一个节点的子节点
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### insertBefore(node, exist)
|
#### insertBefore(node, exist)
|
||||||
|
|
||||||
v0.1.5+
|
v0.1.5+
|
||||||
|
|
||||||
将节点移动到另一个节点的前面
|
将节点移动到另一个节点的前面
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### insertAfter(node, exist)
|
#### insertAfter(node, exist)
|
||||||
|
|
||||||
v0.1.5+
|
v0.1.5+
|
||||||
|
|
||||||
将节点移动到另一个节点的后面
|
将节点移动到另一个节点的后面
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## keyCommand实例
|
## keyCommand实例
|
||||||
|
|
||||||
`keyCommand`实例负责快捷键的添加及触发,内置了一些快捷键,也可以自行添加。可通过`mindMap.keyCommand`获取到该实例。
|
`keyCommand`实例负责快捷键的添加及触发,内置了一些快捷键,也可以自行添加。可通过`mindMap.keyCommand`获取到该实例。
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
### 方法
|
### 方法
|
||||||
|
|
||||||
#### addShortcut(key, fn)
|
#### addShortcut(key, fn)
|
||||||
@ -507,13 +460,10 @@ v0.2.3+。保存当前注册的快捷键数据,然后清空快捷键数据
|
|||||||
|
|
||||||
v0.2.3+。恢复保存的快捷键数据,然后清空缓存数据
|
v0.2.3+。恢复保存的快捷键数据,然后清空缓存数据
|
||||||
|
|
||||||
|
|
||||||
## command实例
|
## command实例
|
||||||
|
|
||||||
`command`实例负责命令的添加及执行,内置了很多命令,也可以自行添加,命令指需要在历史堆栈数据里添加副本的操作。可通过`mindMap.command`获取到该实例
|
`command`实例负责命令的添加及执行,内置了很多命令,也可以自行添加,命令指需要在历史堆栈数据里添加副本的操作。可通过`mindMap.command`获取到该实例
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
### 方法
|
### 方法
|
||||||
|
|
||||||
#### add(name, fn)
|
#### add(name, fn)
|
||||||
@ -524,8 +474,6 @@ v0.2.3+。恢复保存的快捷键数据,然后清空缓存数据
|
|||||||
|
|
||||||
`fn`:命令要执行的方法
|
`fn`:命令要执行的方法
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### remove(name, fn)
|
#### remove(name, fn)
|
||||||
|
|
||||||
移除命令。
|
移除命令。
|
||||||
@ -534,8 +482,6 @@ v0.2.3+。恢复保存的快捷键数据,然后清空缓存数据
|
|||||||
|
|
||||||
`fn`:要移除的方法,不传的话移除该命令所有的方法
|
`fn`:要移除的方法,不传的话移除该命令所有的方法
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### getCopyData()
|
#### getCopyData()
|
||||||
|
|
||||||
获取渲染树数据副本
|
获取渲染树数据副本
|
||||||
@ -544,81 +490,58 @@ v0.2.3+。恢复保存的快捷键数据,然后清空缓存数据
|
|||||||
|
|
||||||
清空历史堆栈数据
|
清空历史堆栈数据
|
||||||
|
|
||||||
|
|
||||||
## view实例
|
## view实例
|
||||||
|
|
||||||
`view`实例负责视图操作,可通过`mindMap.view`获取到该实例
|
`view`实例负责视图操作,可通过`mindMap.view`获取到该实例
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
### 方法
|
### 方法
|
||||||
|
|
||||||
#### translateX(step)
|
#### translateX(step)
|
||||||
|
|
||||||
`x`方向进行平移,`step`:要平移的像素
|
`x`方向进行平移,`step`:要平移的像素
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### translateY(step)
|
#### translateY(step)
|
||||||
|
|
||||||
`y`方向进行平移,`step`:要平移的像素
|
`y`方向进行平移,`step`:要平移的像素
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### reset()
|
#### reset()
|
||||||
|
|
||||||
恢复到默认的变换
|
恢复到默认的变换
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### narrow()
|
#### narrow()
|
||||||
|
|
||||||
缩小
|
缩小
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### enlarge()
|
#### enlarge()
|
||||||
|
|
||||||
放大
|
放大
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### getTransformData()
|
#### getTransformData()
|
||||||
|
|
||||||
v0.1.1+
|
v0.1.1+
|
||||||
|
|
||||||
获取当前变换数据,可用于回显
|
获取当前变换数据,可用于回显
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### setTransformData(data)
|
#### setTransformData(data)
|
||||||
|
|
||||||
v0.1.1+
|
v0.1.1+
|
||||||
|
|
||||||
动态设置变换数据,可以通过getTransformData方法获取变换数据
|
动态设置变换数据,可以通过getTransformData方法获取变换数据
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## doExport实例
|
## doExport实例
|
||||||
|
|
||||||
`doExport`实例负责导出,可通过`mindMap.doExport`获取到该实例
|
`doExport`实例负责导出,可通过`mindMap.doExport`获取到该实例
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
### 方法
|
### 方法
|
||||||
|
|
||||||
#### png()
|
#### png()
|
||||||
|
|
||||||
导出为`png`,异步方法,返回图片数据,`data:url`数据,可以自行下载或显示
|
导出为`png`,异步方法,返回图片数据,`data:url`数据,可以自行下载或显示
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### svg()
|
#### svg()
|
||||||
|
|
||||||
导出为`svg`,异步方法,返回`svg`数据,`data:url`数据,可以自行下载或显示
|
导出为`svg`,异步方法,返回`svg`数据,`data:url`数据,可以自行下载或显示
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### getSvgData()
|
#### getSvgData()
|
||||||
|
|
||||||
获取`svg`数据,异步方法,返回一个对象:
|
获取`svg`数据,异步方法,返回一个对象:
|
||||||
@ -630,28 +553,20 @@ v0.1.1+
|
|||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## select实例
|
## select实例
|
||||||
|
|
||||||
`select`实例负责鼠标右键多选节点操作,可通过`mindMap.select`获取到该实例
|
`select`实例负责鼠标右键多选节点操作,可通过`mindMap.select`获取到该实例
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
### 方法
|
### 方法
|
||||||
|
|
||||||
#### toPos(x, y)
|
#### toPos(x, y)
|
||||||
|
|
||||||
转换鼠标位置为相对于容器`el`的位置
|
转换鼠标位置为相对于容器`el`的位置
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## batchExecution实例
|
## batchExecution实例
|
||||||
|
|
||||||
`batchExecution`用来批量异步的执行一些操作,如果某个操作同时多次调用,那么只会在下一个事件循环里执行一次。可以通过`mindMap.batchExecution`获取到该实例
|
`batchExecution`用来批量异步的执行一些操作,如果某个操作同时多次调用,那么只会在下一个事件循环里执行一次。可以通过`mindMap.batchExecution`获取到该实例
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
### 方法
|
### 方法
|
||||||
|
|
||||||
#### push(name, fn)
|
#### push(name, fn)
|
||||||
@ -662,146 +577,100 @@ v0.1.1+
|
|||||||
|
|
||||||
`fn`:任务
|
`fn`:任务
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## node实例
|
## node实例
|
||||||
|
|
||||||
每个节点都会实例化一个`node`实例
|
每个节点都会实例化一个`node`实例
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
### 属性
|
### 属性
|
||||||
|
|
||||||
#### nodeData
|
#### nodeData
|
||||||
|
|
||||||
该节点对应的真实数据
|
该节点对应的真实数据
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### uid
|
#### uid
|
||||||
|
|
||||||
该节点唯一的标识
|
该节点唯一的标识
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### isRoot
|
#### isRoot
|
||||||
|
|
||||||
是否是根节点
|
是否是根节点
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### layerIndex
|
#### layerIndex
|
||||||
|
|
||||||
节点层级
|
节点层级
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### width
|
#### width
|
||||||
|
|
||||||
节点的宽
|
节点的宽
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### height
|
#### height
|
||||||
|
|
||||||
节点的高
|
节点的高
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### left
|
#### left
|
||||||
|
|
||||||
节点的`left`位置
|
节点的`left`位置
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### top
|
#### top
|
||||||
|
|
||||||
节点的`top`位置
|
节点的`top`位置
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### parent
|
#### parent
|
||||||
|
|
||||||
节点的父节点
|
节点的父节点
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### children
|
#### children
|
||||||
|
|
||||||
节点的子节点列表
|
节点的子节点列表
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### group
|
#### group
|
||||||
|
|
||||||
节点是内容容器,`svg`对象
|
节点是内容容器,`svg`对象
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### isDrag
|
#### isDrag
|
||||||
|
|
||||||
v0.1.5+
|
v0.1.5+
|
||||||
|
|
||||||
节点是否正在拖拽中
|
节点是否正在拖拽中
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
### 方法
|
### 方法
|
||||||
|
|
||||||
#### addChildren(node)
|
#### addChildren(node)
|
||||||
|
|
||||||
添加子节点
|
添加子节点
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### getSize()
|
#### getSize()
|
||||||
|
|
||||||
计算节点的宽高,返回一个布尔值,代表是否宽高发生了变化
|
计算节点的宽高,返回一个布尔值,代表是否宽高发生了变化
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### renderNode()
|
#### renderNode()
|
||||||
|
|
||||||
渲染节点到画布,会移除旧的内容节点,创建新的
|
渲染节点到画布,会移除旧的内容节点,创建新的
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### render()
|
#### render()
|
||||||
|
|
||||||
递归渲染该节点及其所有子节点,第一次调用会创建节点内容,后续只会更新节点位置,想要重新渲染内容,可以先把`initRender`属性设为`true`
|
递归渲染该节点及其所有子节点,第一次调用会创建节点内容,后续只会更新节点位置,想要重新渲染内容,可以先把`initRender`属性设为`true`
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### remove()
|
#### remove()
|
||||||
|
|
||||||
递归删除该节点及其所有子节点
|
递归删除该节点及其所有子节点
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### renderLine()
|
#### renderLine()
|
||||||
|
|
||||||
重新渲染该节点到其子节点之间的连线
|
重新渲染该节点到其子节点之间的连线
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### removeLine()
|
#### removeLine()
|
||||||
|
|
||||||
移除该节点到其子节点之间的连线
|
移除该节点到其子节点之间的连线
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### renderExpandBtn()
|
#### renderExpandBtn()
|
||||||
|
|
||||||
渲染展开收缩按钮的内容
|
渲染展开收缩按钮的内容
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### removeExpandBtn()
|
#### removeExpandBtn()
|
||||||
|
|
||||||
移除展开收缩按钮
|
移除展开收缩按钮
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### getStyle(prop, root, isActive)
|
#### getStyle(prop, root, isActive)
|
||||||
|
|
||||||
获取某个最终应用到该节点的样式值
|
获取某个最终应用到该节点的样式值
|
||||||
@ -812,150 +681,108 @@ v0.1.5+
|
|||||||
|
|
||||||
`isActive`:获取的是否是激活状态的样式值,默认`false`
|
`isActive`:获取的是否是激活状态的样式值,默认`false`
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### setStyle(prop, value, isActive)
|
#### setStyle(prop, value, isActive)
|
||||||
|
|
||||||
修改节点的某个样式,`SET_NODE_STYLE`命令的快捷方法
|
修改节点的某个样式,`SET_NODE_STYLE`命令的快捷方法
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### getData(key)
|
#### getData(key)
|
||||||
|
|
||||||
获取该节点真实数据`nodeData`的`data`对象里的指定值,`key`不传返回这个`data`对象
|
获取该节点真实数据`nodeData`的`data`对象里的指定值,`key`不传返回这个`data`对象
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### setData(data)
|
#### setData(data)
|
||||||
|
|
||||||
设置节点数据,`SET_NODE_DATA`命令的快捷方法
|
设置节点数据,`SET_NODE_DATA`命令的快捷方法
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### setText(text)
|
#### setText(text)
|
||||||
|
|
||||||
设置节点文本,`SET_NODE_TEXT`命令的快捷方法
|
设置节点文本,`SET_NODE_TEXT`命令的快捷方法
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### setImage(imgData)
|
#### setImage(imgData)
|
||||||
|
|
||||||
设置节点图片,`SET_NODE_IMAGE`命令的快捷方法
|
设置节点图片,`SET_NODE_IMAGE`命令的快捷方法
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### setIcon(icons)
|
#### setIcon(icons)
|
||||||
|
|
||||||
设置节点图标,`SET_NODE_ICON`命令的快捷方法
|
设置节点图标,`SET_NODE_ICON`命令的快捷方法
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### setHyperlink(link, title)
|
#### setHyperlink(link, title)
|
||||||
|
|
||||||
设置节点超链接,`SET_NODE_HYPERLINK`命令的快捷方法
|
设置节点超链接,`SET_NODE_HYPERLINK`命令的快捷方法
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### setNote(note)
|
#### setNote(note)
|
||||||
|
|
||||||
设置节点备注,`SET_NODE_NOTE`命令的快捷方法
|
设置节点备注,`SET_NODE_NOTE`命令的快捷方法
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### setTag(tag)
|
#### setTag(tag)
|
||||||
|
|
||||||
设置节点标签,`SET_NODE_TAG`的快捷方法
|
设置节点标签,`SET_NODE_TAG`的快捷方法
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### hide()
|
#### hide()
|
||||||
|
|
||||||
v0.1.5+
|
v0.1.5+
|
||||||
|
|
||||||
隐藏节点及其下级节点
|
隐藏节点及其下级节点
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### show()
|
#### show()
|
||||||
|
|
||||||
v0.1.5+
|
v0.1.5+
|
||||||
|
|
||||||
显示节点及其下级节点
|
显示节点及其下级节点
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### isParent(node)
|
#### isParent(node)
|
||||||
|
|
||||||
v0.1.5+
|
v0.1.5+
|
||||||
|
|
||||||
检测当前节点是否是某个节点的祖先节点
|
检测当前节点是否是某个节点的祖先节点
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### isBrother(node)
|
#### isBrother(node)
|
||||||
|
|
||||||
v0.1.5+
|
v0.1.5+
|
||||||
|
|
||||||
检测当前节点是否是某个节点的兄弟节点
|
检测当前节点是否是某个节点的兄弟节点
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### checkHasGeneralization()
|
#### checkHasGeneralization()
|
||||||
|
|
||||||
v0.2.0+
|
v0.2.0+
|
||||||
|
|
||||||
检查是否存在概要
|
检查是否存在概要
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### hideGeneralization()
|
#### hideGeneralization()
|
||||||
|
|
||||||
v0.2.0+
|
v0.2.0+
|
||||||
|
|
||||||
隐藏概要节点
|
隐藏概要节点
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### showGeneralization()
|
#### showGeneralization()
|
||||||
|
|
||||||
v0.2.0+
|
v0.2.0+
|
||||||
|
|
||||||
显示概要节点
|
显示概要节点
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### updateGeneralization()
|
#### updateGeneralization()
|
||||||
|
|
||||||
v0.2.0+
|
v0.2.0+
|
||||||
|
|
||||||
更新概要节点
|
更新概要节点
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### hasCustomPosition()
|
#### hasCustomPosition()
|
||||||
|
|
||||||
v0.2.0+
|
v0.2.0+
|
||||||
|
|
||||||
检查节点是否存在自定义数据
|
检查节点是否存在自定义数据
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### ancestorHasCustomPosition()
|
#### ancestorHasCustomPosition()
|
||||||
|
|
||||||
v0.2.0+
|
v0.2.0+
|
||||||
|
|
||||||
检查节点是否存在自定义位置的祖先节点
|
检查节点是否存在自定义位置的祖先节点
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### getShape()
|
#### getShape()
|
||||||
|
|
||||||
v0.2.4+
|
v0.2.4+
|
||||||
|
|
||||||
获取节点形状
|
获取节点形状
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### setShape(shape)
|
#### setShape(shape)
|
||||||
|
|
||||||
v0.2.4+
|
v0.2.4+
|
||||||
@ -980,7 +807,6 @@ v0.2.5+
|
|||||||
|
|
||||||
获取自身可继承的自定义样式
|
获取自身可继承的自定义样式
|
||||||
|
|
||||||
|
|
||||||
## 内置工具方法
|
## 内置工具方法
|
||||||
|
|
||||||
引用:
|
引用:
|
||||||
@ -989,8 +815,6 @@ v0.2.5+
|
|||||||
import {walk, ...} from 'simple-mind-map/src/utils'
|
import {walk, ...} from 'simple-mind-map/src/utils'
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
### 方法
|
### 方法
|
||||||
|
|
||||||
#### walk(root, parent, beforeCallback, afterCallback, isRoot, layerIndex = 0, index = 0)
|
#### walk(root, parent, beforeCallback, afterCallback, isRoot, layerIndex = 0, index = 0)
|
||||||
@ -1017,14 +841,10 @@ import {walk, ...} from 'simple-mind-map/src/utils'
|
|||||||
walk(tree, null, () => {}, () => {}, false, 0, 0)
|
walk(tree, null, () => {}, () => {}, false, 0, 0)
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### bfsWalk(root, callback)
|
#### bfsWalk(root, callback)
|
||||||
|
|
||||||
广度优先遍历树
|
广度优先遍历树
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### resizeImgSize(width, height, maxWidth, maxHeight)
|
#### resizeImgSize(width, height, maxWidth, maxHeight)
|
||||||
|
|
||||||
缩放图片的尺寸
|
缩放图片的尺寸
|
||||||
@ -1039,20 +859,14 @@ walk(tree, null, () => {}, () => {}, false, 0, 0)
|
|||||||
|
|
||||||
`maxWidth`和`maxHeight`可以同时都传,也可以只传一个
|
`maxWidth`和`maxHeight`可以同时都传,也可以只传一个
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### resizeImg(imgUrl, maxWidth, maxHeight)
|
#### resizeImg(imgUrl, maxWidth, maxHeight)
|
||||||
|
|
||||||
缩放图片,内部先加载图片,然后调用`resizeImgSize`方法,返回一个`promise`
|
缩放图片,内部先加载图片,然后调用`resizeImgSize`方法,返回一个`promise`
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### simpleDeepClone(data)
|
#### simpleDeepClone(data)
|
||||||
|
|
||||||
极简的深拷贝方法,只能针对全是基本数据的对象,否则会报错
|
极简的深拷贝方法,只能针对全是基本数据的对象,否则会报错
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### copyRenderTree(tree, root)
|
#### copyRenderTree(tree, root)
|
||||||
|
|
||||||
复制渲染树数据,示例:
|
复制渲染树数据,示例:
|
||||||
@ -1061,8 +875,6 @@ walk(tree, null, () => {}, () => {}, false, 0, 0)
|
|||||||
copyRenderTree({}, this.mindMap.renderer.renderTree)
|
copyRenderTree({}, this.mindMap.renderer.renderTree)
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### copyNodeTree(tree, root)
|
#### copyNodeTree(tree, root)
|
||||||
|
|
||||||
复制节点树数据,主要是剔除其中的引用`node`实例的`_node`,然后复制`data`对象的数据,示例:
|
复制节点树数据,主要是剔除其中的引用`node`实例的`_node`,然后复制`data`对象的数据,示例:
|
||||||
@ -1071,32 +883,22 @@ copyRenderTree({}, this.mindMap.renderer.renderTree)
|
|||||||
copyNodeTree({}, node)
|
copyNodeTree({}, node)
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### imgToDataUrl(src)
|
#### imgToDataUrl(src)
|
||||||
|
|
||||||
图片转成dataURL
|
图片转成dataURL
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### downloadFile(file, fileName)
|
#### downloadFile(file, fileName)
|
||||||
|
|
||||||
下载文件
|
下载文件
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### throttle(fn, time = 300, ctx)
|
#### throttle(fn, time = 300, ctx)
|
||||||
|
|
||||||
节流函数
|
节流函数
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#### asyncRun(taskList, callback = () => {})
|
#### asyncRun(taskList, callback = () => {})
|
||||||
|
|
||||||
异步执行任务队列,多个任务是同步执行的,没有先后顺序
|
异步执行任务队列,多个任务是同步执行的,没有先后顺序
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# 特别说明
|
# 特别说明
|
||||||
|
|
||||||
本项目较粗糙,未进行完整测试,功能尚不是很完善,性能也存在一些问题,仅用于学习和参考,请勿用于实际项目。
|
本项目较粗糙,未进行完整测试,功能尚不是很完善,性能也存在一些问题,仅用于学习和参考,请勿用于实际项目。
|
||||||
|
|||||||
@ -1 +1 @@
|
|||||||
<!DOCTYPE html><html lang=""><head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width,initial-scale=1"><title>一个简单的web思维导图实现</title><link href="dist/js/chunk-2d20ec02.81d632f4.js" rel="prefetch"><link href="dist/js/chunk-2d216b67.228f2009.js" rel="prefetch"><link href="dist/js/chunk-35b0a040.cb76da7d.js" rel="prefetch"><link href="dist/css/app.9be46b7b.css" rel="preload" as="style"><link href="dist/css/chunk-vendors.6fd71983.css" rel="preload" as="style"><link href="dist/js/app.91233d74.js" rel="preload" as="script"><link href="dist/js/chunk-vendors.e4b722f1.js" rel="preload" as="script"><link href="dist/css/chunk-vendors.6fd71983.css" rel="stylesheet"><link href="dist/css/app.9be46b7b.css" rel="stylesheet"></head><body><noscript><strong>We're sorry but thoughts doesn't work properly without JavaScript enabled. Please enable it to continue.</strong></noscript><div id="app"></div><script src="dist/js/chunk-vendors.e4b722f1.js"></script><script src="dist/js/app.91233d74.js"></script></body></html>
|
<!DOCTYPE html><html lang=""><head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width,initial-scale=1"><title>一个简单的web思维导图实现</title><link href="dist/js/chunk-2d20ec02.10aa67e3.js" rel="prefetch"><link href="dist/js/chunk-2d216b67.2d06497a.js" rel="prefetch"><link href="dist/js/chunk-5397ae43.9dca0f90.js" rel="prefetch"><link href="dist/css/app.a172fa3f.css" rel="preload" as="style"><link href="dist/css/chunk-vendors.597033a2.css" rel="preload" as="style"><link href="dist/js/app.cb927d32.js" rel="preload" as="script"><link href="dist/js/chunk-vendors.07ae01de.js" rel="preload" as="script"><link href="dist/css/chunk-vendors.597033a2.css" rel="stylesheet"><link href="dist/css/app.a172fa3f.css" rel="stylesheet"></head><body><noscript><strong>We're sorry but thoughts doesn't work properly without JavaScript enabled. Please enable it to continue.</strong></noscript><div id="app"></div><script src="dist/js/chunk-vendors.07ae01de.js"></script><script src="dist/js/app.cb927d32.js"></script></body></html>
|
||||||
@ -828,7 +828,7 @@ class Node {
|
|||||||
this.showGeneralization()
|
this.showGeneralization()
|
||||||
if (this.parent) {
|
if (this.parent) {
|
||||||
let index = this.parent.children.indexOf(this)
|
let index = this.parent.children.indexOf(this)
|
||||||
this.parent._lines[index].show()
|
this.parent._lines[index] && this.parent._lines[index].show()
|
||||||
}
|
}
|
||||||
// 子节点
|
// 子节点
|
||||||
if (this.children && this.children.length) {
|
if (this.children && this.children.length) {
|
||||||
|
|||||||
@ -784,10 +784,7 @@ class Render {
|
|||||||
node.data.expand = true
|
node.data.expand = true
|
||||||
}
|
}
|
||||||
}, null, true, 0, 0)
|
}, null, true, 0, 0)
|
||||||
this.mindMap.render()
|
this.mindMap.reRender()
|
||||||
this.root.children.forEach((item) => {
|
|
||||||
item.updateExpandBtnNode()
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -796,14 +793,13 @@ class Render {
|
|||||||
* @Desc: 收起所有
|
* @Desc: 收起所有
|
||||||
*/
|
*/
|
||||||
unexpandAllNode() {
|
unexpandAllNode() {
|
||||||
this.root.children.forEach((item) => {
|
|
||||||
this.setNodeExpand(item, false)
|
|
||||||
})
|
|
||||||
walk(this.renderTree, null, (node, parent, isRoot) => {
|
walk(this.renderTree, null, (node, parent, isRoot) => {
|
||||||
|
node._node = null
|
||||||
if (!isRoot) {
|
if (!isRoot) {
|
||||||
node.data.expand = false
|
node.data.expand = false
|
||||||
}
|
}
|
||||||
}, null, true, 0, 0)
|
}, null, true, 0, 0)
|
||||||
|
this.mindMap.reRender()
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -814,6 +810,7 @@ class Render {
|
|||||||
*/
|
*/
|
||||||
expandToLevel(level) {
|
expandToLevel(level) {
|
||||||
walk(this.renderTree, null, (node, parent, isRoot, layerIndex) => {
|
walk(this.renderTree, null, (node, parent, isRoot, layerIndex) => {
|
||||||
|
node._node = null
|
||||||
node.data.expand = layerIndex < level
|
node.data.expand = layerIndex < level
|
||||||
}, null, true, 0, 0)
|
}, null, true, 0, 0)
|
||||||
this.mindMap.reRender()
|
this.mindMap.reRender()
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user