这一段时间一直在做一个博客项目 ,找了一圈发现没有特别满足自己需求的目录组件,所以决定自己动手,完成一个满足以下预期目标的目录组件:
完成后的目录组件如下图左侧所示:
由于标题之间有父子的关系,所以我们应该用树数据结构来解决这个问题。我们遍历文章容器中的所有标签,如果遇到 <h1>
、<h2>
这类标签,就创建一个节点,将其放到列表中,之后使用 v-for
指令来生成目录就行了。下面分析一下每个节点需要有哪些属性。
一个树的节点,应该具有的属性包括:父节点的指针 parent
、子节点的指针列表 children
,因为一个节点代表一个标题,所以还要包含:标题的 ID号 id
(用于 v-for
的 key
),标题名
name
(添加了标题的序号)、原始标题名 rawName
和标题的可见性 isVisible
,当我们点击标题时,应该滚动到标题的位置,所以还要有 scrollTop
属性。在我们遍历文章容器中的所有标签时,需要判断当前遇到的标签和上一个标签之间的父子关系,所以要有一个
level
属性代表每一个节点的等级。下面是具体实现代码:
这是一个自动轮播播放图,来让我们看一下代码:(用到的主要是对定时器和css样式的调节)
先来看一下created和data里面的数据逻辑
然后再看一下methods里面的方法
接下来,在页面销毁之前我们要把定时器给关闭 在beforeDestroy里面操作
把界面改了一下,开始实际填充功能。
它把命令组织成一组“标签”,每一组包含了相关的命令。每一个应用程序都有一个不同的标签组,展示了程序所提供的功能。在每个标签里,各种的相关的选项被组在一起。设计Ribbon的目的是为了使应用程序的功能更加易于发现和使用,减少了点击鼠标的次数。
简单的说,就是目前最新版office办公套件的那种风格。这种界面样式比菜单栏&工具栏的组织更易操作。
不多说,直接看截图吧。
项目开源在下面的链接中
把界面改了一下,开始实际填充功能。
它把命令组织成一组“标签”,每一组包含了相关的命令。每一个应用程序都有一个不同的标签组,展示了程序所提供的功能。在每个标签里,各种的相关的选项被组在一起。设计Ribbon的目的是为了使应用程序的功能更加易于发现和使用,减少了点击鼠标的次数。
简单的说,就是目前最新版office办公套件的那种风格。这种界面样式比菜单栏&工具栏的组织更易操作。
不多说,直接看截图吧。
项目开源在下面的链接中
把界面改了一下,开始实际填充功能。
它把命令组织成一组“标签”,每一组包含了相关的命令。每一个应用程序都有一个不同的标签组,展示了程序所提供的功能。在每个标签里,各种的相关的选项被组在一起。设计Ribbon的目的是为了使应用程序的功能更加易于发现和使用,减少了点击鼠标的次数。
简单的说,就是目前最新版office办公套件的那种风格。这种界面样式比菜单栏&工具栏的组织更易操作。
不多说,直接看截图吧。
项目开源在下面的链接中
版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。