对于锚点定位来说,主要涉及这两个部分:
设置锚点,为页面中的某个组件添加id属性
点击链接,跳转到指定锚点处
例如:
// 锚点组件
function AnchorComponent() {...Chapter
key={chapter.id}
chapter={chapter}
/>
))}
)
}
给Nav组件传一个...服务端渲染的静态HTML中,并没有绑定滚动事件,所以无法自动高亮。
预取数据
首先,我们需要解决点击目录链接的问题。
既然服务端无法获取组件ref,那就需要在客户端去获取元素位置。...这样我们就可以在点击目录链接时,正确滚动到对应的章节位置了。
数据注水
但是点击目录只解决了一半问题,滚动高亮还需要解决。
这里就需要用到数据注水的技术。...简单来说就是:
在服务端渲染时,读取路由参数,提前计算高亮状态
将高亮数据注入到响应中
客户端拿到注水的数据后渲染,不会出现高亮错位
实现步骤:
1.服务端获取参数和数据
// 在getServerSideProps