react-scroll
react-scroll copied to clipboard
activeClass
activeClass property does not work in tailwindcss with utility classes is there a workaround to get it worked?
i have same issues. But, still dont understand. How tailwindcss can influence react-scroll?
Could you provide a codepen/plunkr demonstrating the issue? Would be easier for me.
@fisshy same issue here, also using tailwindcss. I have no warnings, no console errors, but the activeClass doesn't show on click navigation.
I have the same issue with Nextjs (without tailwindcss). None of the activeClass
gets applied in my project.
I have the same issue with Nextjs (without tailwindcss). None of the
activeClass
gets applied in my project.
Any chance you forgot to apply the spy
and/or hashSpy
prop depending on your needs? I remember having similar issues when I first started using the library without reading the docs.
Hi fisshy, my problem is probably a bit more basic.
the first link shows the activeClass styling, but the other links don't. See attached images of code and result.
Am I perhaps not using the props correctly?
data:image/s3,"s3://crabby-images/2331a/2331ac35dd83cddd1cfb39d0d7cc10b1c98c0486" alt="Screen Shot 2020-12-27 at 12 29 30 PM"
data:image/s3,"s3://crabby-images/1672e/1672e5efae7d497d5b51ce3bb270cd9478fb64de" alt="Screen Shot 2020-12-27 at 12 27 24 PM"
data:image/s3,"s3://crabby-images/0d960/0d96056b941b6ab80a918e977f55222ab65bc0d1" alt="Screen Shot 2020-12-27 at 12 27 23 PM"
data:image/s3,"s3://crabby-images/9bc65/9bc65b2fc8599fd4787c0e7db2d013cf2feced50" alt="Screen Shot 2020-12-27 at 12 27 11 PM"
data:image/s3,"s3://crabby-images/58542/58542c722b44e28da2ab314088305279bc0ceeff" alt="Screen Shot 2020-12-27 at 12 27 09 PM"
data:image/s3,"s3://crabby-images/53f76/53f76e3e3a14f0109eeeac06b066e5b78d76c3e6" alt="Screen Shot 2020-12-27 at 12 27 04 PM"
I think my problem is similar. All link work if top of page is near. But I need it always. In my example on my last three item active never apply.
This is little bit stupid. I want active class on click can I get this out of box?
I'm pretty sure that it should work. What browser are you using?
I'm not sure how that rest of the code looks like. But this "basic" setup works for me, when it comes to Link/activeClass.
https://codesandbox.io/s/basic-6t84k
wrap scroll content in <Element name = '...' />
I found a better way to do it by using IntersectionObserver API.
This is the example code for the custom Link
:
const NavLink = ({ to, text, ...props }) => {
const [active, setActive] = useState(false)
useEffect(() => {
const ioOptions = {
threshold: 0.5,
}
const ioCallback = (entries, observer) => {
const entry = entries[0]
setActive(entry.isIntersecting)
}
const observer = new IntersectionObserver(ioCallback, ioOptions)
observer.observe(document.querySelector(`#${to}`))
}, [to])
return (
<ScrollLink
className={`cursor-pointer hover:text-green-500 p-2 ${
active ? 'border-b-2 border-green-500' : ''
}`}
smooth
offset={-80}
to={to}
{...props}
>
{text}
</ScrollLink>
)
}
Basically, the idea is only use react-scroll
for smooth-scroll effect, and use IntersectionObserver to detect the active section.
Note: I don't know why but it's not working with react-scroll <Element name={id} />
, using <div id={id} />
instead.