解析降级到自动表中的目录
本教程演示了为长形式:标记内容创建交互式目录。它利用几种技术来增强用户体验,包括降压解析,交叉观察者进行主动截面检测,平滑滚动动画以及用于动画列表更新的VUE.JS过渡。
目录在页面内提供快速导航。这对于冗长的文章特别有用,为用户提供了清晰的概述和轻松访问不同部分的访问。本指南详细介绍了如何将标记文本转换为带有链接标题的HTML目录,突出显示了当前查看的部分。我们还将使用vue.js实现流畅的滚动和动画列表更新。
降级解析和HTML生成
Web内容通常使用Markdown。我们将采用marked
库(尽管替代方案是合适的)将降价分析到HTML中。降价内容是从GitHub Gist获取的。 marked
函数将获取的Markdown文本转换为HTML,然后将其注入到DOM中。
1 2 3 4 5 6 7 |
|
使用innerHTML
将解析的HTML插入指定的DOM元素。
1 2 3 4 5 6 7 |
|
生成目录
下一步是从分析的HTML中的标题(H1和H2)创建目录。我们使用querySelectorAll
来选择这些标题,提取其文本内容,深度(H1或H2)和ID属性。
1 2 3 4 5 6 7 8 9 |
|
这会生成一系列对象,每个对象代表标题。然后,该数据用于使用ES6模板文字为目录创建HTML,从而为子头增长了凹痕(H2)。所得的HTML被添加到外部元素中。
实施交叉点观察者
为了动态强调目录中的活动部分,我们使用交叉点观察者API。此API允许我们监视元素(在这种情况下,标题)与视口相交时。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
|
handleObserver
函数检查交叉点,并调用updateLinks
从目录中的相应链接中添加/删除is-active
类。
光滑滚动和链接点击处理
单击内容表中的链接应平滑滚动到相应的部分。我们将事件侦听器添加到每个链接,防止默认行为和使用window.scroll
使用smooth
行为”选项(除非用户更喜欢减少运动)。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
|
用vue.js对目录进行动画表
最后,vue.js的<transition-group></transition-group>
组件用于对目录中列表项目的添加和删除进行动画。当部分变得活跃或不活动时,这提供了平稳的转变。定义了适当的CSS过渡以处理动画。 (对于简洁而言,省略了VUE集成和CSS的代码,但构成了实施的最后一部分。)建议访问功能以防止快速滚动的动画问题。
这种完整的方法提供了高度交互式且用户友好的目录,用于长形式:标记内容。
以上是解析降级到自动表中的目录的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

您是否曾经在项目上需要一个倒计时计时器?对于这样的东西,可以自然访问插件,但实际上更多

格子呢是一块图案布,通常与苏格兰有关,尤其是他们时尚的苏格兰语。在Tartanify.com上,我们收集了5,000多个格子呢

我关注的一件事是Lea Verou&#039; s conic-Gradient()Polyfill的功能列表是最后一项:
