本教程演示了为长形式:标记内容创建交互式目录。它利用几种技术来增强用户体验,包括降压解析,交叉观察者进行主动截面检测,平滑滚动动画以及用于动画列表更新的VUE.JS过渡。
目录在页面内提供快速导航。这对于冗长的文章特别有用,为用户提供了清晰的概述和轻松访问不同部分的访问。本指南详细介绍了如何将标记文本转换为带有链接标题的HTML目录,突出显示了当前查看的部分。我们还将使用vue.js实现流畅的滚动和动画列表更新。
降级解析和HTML生成
Web内容通常使用Markdown。我们将采用marked
库(尽管替代方案是合适的)将降价分析到HTML中。降价内容是从GitHub Gist获取的。 marked
函数将获取的Markdown文本转换为HTML,然后将其注入到DOM中。
异步函数fetchandparsemarkdown(){ const url ='https://gist.githubusercontent.com/lisilinhart/e9dcf5298adff7c2c2a4da4da9ce2a3db3db3f/raw/raw/2f1a0d47eba647eba647564756c222460b5dd2291919191919198d45454545454542MM const响应=等待提取(url); const data =等待响应.text(); const htmlFrommarkDown =标记(数据,{sanitize:true}); 返回htmlfrommarkdown; }
使用innerHTML
将解析的HTML插入指定的DOM元素。
异步函数init(){ const $ main = document.queryselector('#app'); const htmlcontent =等待fetchandparsemarkdown(); $ main.innerhtml = htmlContent; } init();
生成目录
下一步是从分析的HTML中的标题(H1和H2)创建目录。我们使用querySelectorAll
来选择这些标题,提取其文本内容,深度(H1或H2)和ID属性。
函数generateLinkmarkup($ contentElement){ const标题= [... $ contentElement.querySelectorall('H1,H2')]; const parsedheadings = headings.map(heading =>({{ 标题:heading.innertext, 深度:heading.nodename.replace(/\ d/g,''), id:heading.getAttribute('id') })); // ...(生成HTML标记的其余功能) }
这会生成一系列对象,每个对象代表标题。然后,该数据用于使用ES6模板文字为目录创建HTML,从而为子头增长了凹痕(H2)。所得的HTML被添加到外部元素中。
实施交叉点观察者
为了动态强调目录中的活动部分,我们使用交叉点观察者API。此API允许我们监视元素(在这种情况下,标题)与视口相交时。
函数createObserver($ links){ const options = {rootmargin:“ 0px 0px -200px 0px”,阈值:1}; const callback =(条目,观察者)=> handleObserver(条目,观察者,$ links); //回调处理更新 返回新的IntersectionObserver(回调,选项); } 函数handleobserver(条目,观察者,$ links){ entries.foreach(entry => { if(entry.isintersecting && enter.intersectionratio> = 1){ updateLinks(`#$ {entry.target.getAttribute('id')}`,$ links); } }); } 功能UpdatElinks(visibleId,$ links){ $ links.foreach(link => { link.classlist.remove('IS-Active'); if(link.getAttribute('href')===可见visibleId)link.classlist.add('is-active'); }); }
handleObserver
函数检查交叉点,并调用updateLinks
从目录中的相应链接中添加/删除is-active
类。
光滑滚动和链接点击处理
单击内容表中的链接应平滑滚动到相应的部分。我们将事件侦听器添加到每个链接,防止默认行为和使用window.scroll
使用smooth
行为”选项(除非用户更喜欢减少运动)。
const MotionQuery = window.matchmedia('(prefers-reducce-motion)'); $ links.foreach(link => { link.AddeventListener(“ click”,evt => handlelinkClick(evt,$ headings,motionquery)); }); 功能HandlelinkClick(EVT,$标题,MotionQuery){ evt.preventdefault(); const ID = evt.target.getAttribute(“ href”)。替换('#',''); const部分= $ headings.find(heading => heading.getAttribute('id')=== id); e节。 window.scroll({ 行为:MotionQuery.Matches? 'instant':“平滑”, 顶部:section.offsettop -20 }); }
用vue.js对目录进行动画表
最后,vue.js的<transition-group></transition-group>
组件用于对目录中列表项目的添加和删除进行动画。当部分变得活跃或不活动时,这提供了平稳的转变。定义了适当的CSS过渡以处理动画。 (对于简洁而言,省略了VUE集成和CSS的代码,但构成了实施的最后一部分。)建议访问功能以防止快速滚动的动画问题。
这种完整的方法提供了高度交互式且用户友好的目录,用于长形式:标记内容。
以上是解析降级到自动表中的目录的详细内容。更多信息请关注PHP中文网其他相关文章!

具有CSS的自定义光标很棒,但是我们可以将JavaScript提升到一个新的水平。使用JavaScript,我们可以在光标状态之间过渡,将动态文本放置在光标中,应用复杂的动画并应用过滤器。

互动CSS动画和元素相互启动的元素在2025年似乎更合理。虽然不需要在CSS中实施乒乓球,但CSS的灵活性和力量的增加,可以怀疑Lee&Aver Lee&Aver Lee有一天将是一场

有关利用CSS背景滤波器属性来样式用户界面的提示和技巧。您将学习如何在多个元素之间进行背景过滤器,并将它们与其他CSS图形效果集成在一起以创建精心设计的设计。

好吧,事实证明,SVG的内置动画功能从未按计划进行弃用。当然,CSS和JavaScript具有承载负载的能力,但是很高兴知道Smil并没有像以前那样死在水中

是的,让#039;跳上文字包装:Safari Technology Preview In Pretty Landing!但是请注意,它与在铬浏览器中的工作方式不同。

此CSS-tricks更新了,重点介绍了年鉴,最近的播客出现,新的CSS计数器指南以及增加了几位新作者,这些新作者贡献了有价值的内容。

在大多数情况下,人们展示了@Apply的@Apply功能,其中包括Tailwind的单个property实用程序之一(会改变单个CSS声明)。当以这种方式展示时,@Apply听起来似乎很有希望。如此明显


热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

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

热门文章

热工具

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

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

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。