看到一些树型控件,展开父节点后,父节点和子节点之间,有 dot line 连接,这个是如何实现的?

2021-08-05 08:41:02 +08:00
 yazoox

不知道应该放在 css 还是 react (我司开发,主要用的 react )分类里面。

如图

想请教一下,这个 dot-lines (还带转弯的有竖有横),是怎么画出来的?直接通过 css 么?

谢谢!

1845 次点击
所在节点    React
7 条回复
AlphaTr
2021-08-05 08:47:58 +08:00
直接通过 CSS 来实现吧,垂直方向的给展开的父级来添加 :after 伪元素,水平方向的给每个非根子元素添加伪元素
liyang5945
2021-08-05 09:01:27 +08:00
以前用过一个 ztree 的插件是用背景图实现的
des
2021-08-05 09:17:07 +08:00
通过多个图形组合,图片或者 css 都行,注意调整间距
当然你要用 svg 做整一个也不是不行
jorneyr
2021-08-05 09:22:32 +08:00
可以参考 http://qtdebug.com/qtbook-qss-subcontrol/#QTreeView 这个的图,比较直观的看到树的样式,每一级的缩进都有 n 个 div 块,对每一个块进行计算得到它要填充什么图案。
old9
2021-08-05 10:03:46 +08:00
写过一个简单的,就是用 :before :after 画 border,结构就是基本的 ul >li > (span + ul)
yazoox
2021-08-05 11:37:28 +08:00
@old9 一定要用 ul > li > span 么?我们的 treeview/item 没有用 ul & li
old9
2021-08-06 09:20:19 +08:00
@yazoox 只是举例描述一下结构,ul li 比较好理解层级关系,具体用什么 tag 无所谓,反正是 css 控制

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/793749

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX