前言
锚点目录定位功能在长页面和文档类网站中非常常见,它可以让用户快速定位到页面中的某个章节
如何在React中实现锚点定位和平滑滚动
目录自动高亮的实现思路
处理顶部导航遮挡锚点的解决方案
服务端渲染下的实现方案...常见的解决方案是:
设置锚点元素margin-top
#anchor {
margin-top: 80px; /* header高度 */
}
直接设置一个和Header高度相同的margin,来防止遮挡...SSR支持
在Next.js等SSR场景下,客户端脚本会延后加载,页面初次渲染时目录联动会失效。...chapters} />,
document.getElementById('root')
);
}, []);
}
服务端渲染的实现方案
在使用了服务端渲染(SSR)的框架如Next.js...但是在Next.js的SSR环境下就会有问题:
点击目录链接时,页面不会滚动。
这是因为在服务端,我们无法获取组件的ref,所以锚点元素不存在,自然无法定位。
滚动页面时,目录高亮也失效。