onClick button doesnt work in my project with Next.js 15.1.3 version
Unanswered
Narrow-barred Spanish mackerel posted this in #help-forum
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt="Avatar"
Narrow-barred Spanish mackerelOP
I have a problem in my project that the onClick property on the button tag does not run even though my code is also not an error my debugging also has no changes, I am using next js version 15
10 Replies
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt="Avatar"
Narrow-barred Spanish mackerelOP
NavLink.jsx
import Link from "next/link";
export default function NavLink({ children, url, addClass = "" }) {
return (
<li>
<Link
href={url}
className={
>
{children}
</Link>
</li>
);
}
import Link from "next/link";
export default function NavLink({ children, url, addClass = "" }) {
return (
<li>
<Link
href={url}
className={
block py-2 px-3 rounded ${addClass}
}>
{children}
</Link>
</li>
);
}
index.jsx
"use client";
import { useState } from "react";
import { routes } from "@/routes";
import NavLink from "./NavLink";
export default function Navigation() {
const [isMenuOpen, setIsMenuOpen] = useState(false);
const toggleMenu = () => {
setIsMenuOpen(!isMenuOpen);
console.log('Menu is open:', isMenuOpen);
};
return (
<nav
className={
>
<div className="max-w-screen-xl flex flex-wrap items-center justify-between mx-auto xl:px-0 py-4">
<a href="#" className="flex items-center space-x-3 rtl:space-x-reverse">
<img src="/favicon.png" className="h-8" alt="DevFlex Logo" />
<span className="self-center text-2xl font-semibold whitespace-nowrap">
Jack's
</span>
</a>
"use client";
import { useState } from "react";
import { routes } from "@/routes";
import NavLink from "./NavLink";
export default function Navigation() {
const [isMenuOpen, setIsMenuOpen] = useState(false);
const toggleMenu = () => {
setIsMenuOpen(!isMenuOpen);
console.log('Menu is open:', isMenuOpen);
};
return (
<nav
className={
section-padding-x fixed top-0 w-full z-[998] text-dark-base normal-font-size transition-all duration-300 bg-light-base shadow-md
}>
<div className="max-w-screen-xl flex flex-wrap items-center justify-between mx-auto xl:px-0 py-4">
<a href="#" className="flex items-center space-x-3 rtl:space-x-reverse">
<img src="/favicon.png" className="h-8" alt="DevFlex Logo" />
<span className="self-center text-2xl font-semibold whitespace-nowrap">
Jack's
</span>
</a>
<button
type="button"
className="lg:hidden text-dark-base relative z-[999] focus:outline-none"
onClick={toggleMenu}
>
<svg
xmlns="http://www.w3.org/2000/svg"
fill="currentColor"
className="w-8"
viewBox="0 0 448 512"
>
<path d="M0 96C0 78.3 14.3 64 32 64l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 128C14.3 128 0 113.7 0 96zM0 256c0-17.7 14.3-32 32-32l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 288c-17.7 0-32-14.3-32-32zM448 416c0 17.7-14.3 32-32 32L32 448c-17.7 0-32-14.3-32-32s14.3-32 32-32l384 0c17.7 0 32 14.3 32 32z" />
</svg>
</button>
<div
className={
>
<ul className="font-medium flex flex-col p-4 lg:p-0 mt-4 border rounded-lg lg:flex-row rtl:space-x-reverse lg:mt-0 lg:border-0 gap-2 lg:gap-0">
{routes.map((route, index) => (
<NavLink key={index} url={route.url}>
{route.title}
</NavLink>
))}
</ul>
</div>
</div>
</nav>
);
}
type="button"
className="lg:hidden text-dark-base relative z-[999] focus:outline-none"
onClick={toggleMenu}
>
<svg
xmlns="http://www.w3.org/2000/svg"
fill="currentColor"
className="w-8"
viewBox="0 0 448 512"
>
<path d="M0 96C0 78.3 14.3 64 32 64l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 128C14.3 128 0 113.7 0 96zM0 256c0-17.7 14.3-32 32-32l384 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 288c-17.7 0-32-14.3-32-32zM448 416c0 17.7-14.3 32-32 32L32 448c-17.7 0-32-14.3-32-32s14.3-32 32-32l384 0c17.7 0 32 14.3 32 32z" />
</svg>
</button>
<div
className={
w-full lg:block lg:w-auto ${
isMenuOpen ? "block" : "hidden"
}
}>
<ul className="font-medium flex flex-col p-4 lg:p-0 mt-4 border rounded-lg lg:flex-row rtl:space-x-reverse lg:mt-0 lg:border-0 gap-2 lg:gap-0">
{routes.map((route, index) => (
<NavLink key={index} url={route.url}>
{route.title}
</NavLink>
))}
</ul>
</div>
</div>
</nav>
);
}
data:image/s3,"s3://crabby-images/74791/747912a036d92a8864d6592365f6d69ab169160f" alt="Avatar"
I tested your code snippet and the button does work
maybe something else causing the error ? can you provide a small repo of the error
maybe something else causing the error ? can you provide a small repo of the error
data:image/s3,"s3://crabby-images/2b4e8/2b4e87fddf19f66a5da6c3586544e0a5c754ee15" alt="Image"
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt="Avatar"
Narrow-barred Spanish mackerelOP
here is my repository
https://github.com/JackBerck/cool-portfolio.git
https://github.com/JackBerck/cool-portfolio.git
maybe u can check it and solve it, thanks sir
data:image/s3,"s3://crabby-images/74791/747912a036d92a8864d6592365f6d69ab169160f" alt="Avatar"
Can you try deleting <RootLayout> component from page.js
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt="Avatar"
Narrow-barred Spanish mackerelOP
oh my God... thank you very much, but can I ask. Why does this happen? and in terms of appearance it remains the same even if you dont use a layout
data:image/s3,"s3://crabby-images/74791/747912a036d92a8864d6592365f6d69ab169160f" alt="Avatar"
Layouts are auto applied, you don't have to use it as component for it to work
data:image/s3,"s3://crabby-images/80251/80251c9eef8cd35c541c93d78fdaad57654f4300" alt="Avatar"
Narrow-barred Spanish mackerelOP
Ouh ok, thank you very much sir