这段代码改变了1020 px(1080px屏幕)后导航栏元素的颜色,如果导航栏出现在另一个页面上,但是当我转到另一个页面时,在改变导航栏颜色时会有延迟,直到我开始滚动,有什么方法可以解决这个问题或使它以不同的方式工作?
这里有一个视频演示这一点:https://youtu.be/fdw6WVbqJ30
Codesandbox:https://codesandbox.io/p/sandbox/hotel-app-test-63l7v7?file=%2Fapp%2Fpage.tsx%3A12%2C13
'use client'
import Image from "next/image"
import Link from "next/link"
import Container from "../Container"
import { useState, useEffect, useCallback } from "react";
import { useRouter } from "next/navigation";
const Navbar = () => {
const [color, setColor] = useState(false)
const changeColor = useCallback(() => {
if (window.scrollY >= 950 || window.location.pathname.includes('/lodge')) {
setColor(true);
} else {
setColor(false);
}
}, []);
useEffect(() => {
changeColor();
window.addEventListener('scroll', changeColor);
return () => {
window.removeEventListener('scroll', changeColor);
};
}, []);
const [image, setImage] = useState(false)
const changeImage = useCallback(() => {
if (window.scrollY >= 950 || window.location.pathname.includes('/lodge')) {
setImage(true);
} else {
setImage(false);
}
}, []);
useEffect(() => {
changeImage();
window.addEventListener('scroll', changeImage);
return () => {
window.removeEventListener('scroll', changeImage);
};
}, []);
return (
<div className="fixed w-full backdrop-blur-sm shadow-sm">
<div className="py-4 border-b-[2px]">
<Container>
<div className="flex flex-row items-center justify-between gap-4">
<Link href="/">
{image ? (
<Image className="" src="/images/logo-b.svg" alt="logo-b" width={132} height={58}/>
) : (
<Image className="" src="/images/logo.svg" alt="logo" width={132} height={58}/>
)}
</Link>
<div className="text-2xl text-white font-medium xl:pl-[632px] md:block hidden">
<Link
href="/lodge"
className={color ? 'text-[#313131]' : 'text-white'}
>
LODGE
</Link>
</div>
<div className="text-2xl text-white font-medium md:block hidden">
<div className={color ? 'text-[#313131]' : 'text-white'}>
<Link href="/blog">
OUR BLOG
</Link>
</div>
</div>
<div className="text-white text-2xl font-medium flex flex-row items-center gap-3">
<div className="relative sm:w-5 sm:h-5 md:w-5 md:h-5">
{image ? (
<Image src="/images/tel-b.svg" alt="tel" width={24} height={24}/>
) : (
<Image src="/images/tel.svg" alt="tel-b" width={24} height={24}/>
)}
</div>
<div className="">
<div className={color ? 'text-[#313131]' : 'text-white'}>
NUM
</div>
</div>
</div>
<div className="text-2xl text-white font-medium flex flex-row items-center gap-3">
<div className={color ? 'text-[#313131]' : 'text-white'}>
<div className="sm:block cursor-pointer">
EN
</div>
</div>
<div className={color ? 'text-[#313131]' : 'text-white'}>
|
</div>
<div className={color ? 'text-[#313131]' : 'text-white'}>
<div className="sm:block cursor-pointer">
ES
</div>
</div>
</div>
</div>
</Container>
</div>
</div>
)
}
export default Navbar;
还是没有解决问题
1条答案
按热度按时间qcuzuvrc1#
你必须在每次路径名更改时运行nav颜色更改逻辑,而不仅仅是在滚动时:
工作demo。
image
和color
没有必要是两个独立的状态,因为它们在完全相同的条件下发生变化,所以让一个状态同时导出这两个状态更有意义。在我的示例中,我将其命名为isDark
。