如何在 Nextjs 中的服务器组件中设置活动导航链接的样式

大家好! next.js 现在非常热门,尤其是新版本 15,它添加了许多很酷的功能。但今天的主题不是这个。 next.js 最著名的功能是其基于文件的路由器和内置 ssr(服务器端渲染)。

ssr 是一个复杂的主题,尤其是在同步应用程序的服务器和客户端状态时,很多人选择客户端渲染(csr)。当然,在某些情况下服务器组件是不可行的,但关键是 next.js 基本上是围绕 ssr 构建的,以增强性能和 seo,使其成为受益于服务器渲染的应用程序的强大选择。

soooo,我们如何构建一个导航栏,其中的链接在我们位于某个页面时突出显示?基本方法是迭代一系列链接并突出显示路径名与浏览器中当前路径匹配的链接。要在 next.js 中获取路径名,我们可以使用 usepathname (用于页面路由器的 userouter)挂钩。通过这种方法,我们最终会得到类似的结果:

"use client";import { cn } from "@/lib/utils";import { usepathname } from "next/navigation";import link, { type linkprops } from "next/link";type clientnavprops = {  links: linkprops[];};function clientnav({ links }: clientnavprops) {  const pathname = usepathname();  const isactive = (href: linkprops["href"]) => {    const hrefstr = href.tostring();    if (hrefstr === pathname) return true;    if (hrefstr.length > 1 && pathname.startswith(hrefstr)) return true;    return false;  };  return (      );}export default clientnav;

这是它在浏览器中的外观:

如何在 Nextjs 中的服务器组件中设置活动导航链接的样式

但是,这种方法的问题在于该组件是基于客户端的,这对于 seo 来说并不理想。由于我们无法在服务器组件中调用客户端钩子,因此我们需要解决如何在服务器端获取路径名以将当前链接渲染为突出显示的问题。

无涯·问知 无涯·问知

无涯·问知,是一款基于星环大模型底座,结合个人知识库、企业知识库、法律法规、财经等多种知识源的企业级垂直领域问答产品

无涯·问知 153 查看详情 无涯·问知

而且这个问题并不难回答,这里中间件就派上用场了。使用中间件,我们可以将路径名添加到响应标头中,并对其进行配置,以便为所有页面路由触发:

import { nextresponse } from "next/server";import type { nextrequest } from "next/server";export const config = {  matcher: ["/((?!api|_next/static|_next/image|favicon.ico).*)"],};export default function middleware(request: nextrequest) {  const requestheaders = new headers(request.headers);  requestheaders.set("x-next-pathname", request.nexturl.pathname);  return nextresponse.next({ request: { headers: requestheaders } });}

现在有了带有当前路径名的 x-next-pathname,我们可以使用 headers 函数访问它(请注意,next 15 及以上版本现在具有异步功能:headers、cookie、params 和 searchparams)。

import { cn } from "@/lib/utils";import { headers } from "next/headers";import Link, { type LinkProps } from "next/link";type ClientNavProps = {  links: LinkProps[];};async function ServerNav({ links }: ClientNavProps) {  const headersList = await headers();  const pathname = headersList.get("x-next-pathname") || "/";  const isActive = (href: LinkProps["href"]) => {    const hrefStr = href.toString();    if (hrefStr === pathname) return true;    if (hrefStr.length > 1 && pathname.startsWith(hrefStr)) return true;    return false;  };  return (      );}export default ServerNav;

请谨慎放置服务器导航栏在应用程序中的位置。这个特定的示例仅在 page.tsx 文件内使用时才有效,因为它需要在 url 更改时重新渲染。

这可能是构建突出显示当前活动链接的服务器端导航栏组件的最简单方法。就是这样——感谢您的阅读,我们下次再见!

以上就是如何在 Nextjs 中的服务器组件中设置活动导航链接的样式的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1156376.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月2日 21:06:02
下一篇 2025年12月2日 21:06:19

相关推荐

  • 如何在Windows 11下配置PHP支持HTTPS PHP环境启用SSL证书说明

    要在windows 11上配置php支持https,首先需安装xampp等php环境,其次获取ssl证书,最后配置apache服务器并启用https。1. 安装xampp:从apache friends官网下载安装包,安装并启动apache和mysql,若启动失败需检查端口占用问题。2. 获取ssl…

    2025年12月11日 好文分享
    000
  • 通过URL传递PHP变量以获取特定产品信息

    本文旨在解决在PHP网页间传递变量,从而在产品信息页面准确显示用户点击的产品详情的问题。文章将详细解释如何使用URL参数传递产品ID,并在目标页面通过$_GET方法获取该ID,最终实现动态加载特定产品信息。 在Web开发中,经常需要在不同的页面之间传递数据。对于PHP应用程序,一种常见的场景是从一个…

    2025年12月11日
    000
  • 通过URL参数在PHP页面间传递变量以获取特定数据

    本文旨在帮助PHP初学者解决在多页面应用中通过URL参数传递变量的问题,重点讲解如何使用$_GET方法在页面间传递产品ID,并在目标页面根据该ID从数据库中获取并展示相应的商品信息。文章将通过示例代码和注意事项,深入浅出地阐述实现过程,避免不必要的Ajax调用,简化代码逻辑。 在PHP Web应用开…

    2025年12月11日
    000
  • 如何用Windows 11配置PHP URL重写规则 PHP伪静态配置与调试方法

    配置php url重写规则的关键在于安装url rewrite模块、创建或修改web.config文件、编写重写规则、保存并测试。1. 安装url rewrite模块:通过“控制面板”-“程序”-“启用或关闭windows功能”,找到iis相关选项并勾选“url重写”进行安装。2. 创建或修改web…

    2025年12月11日 好文分享
    000
  • PHP与FPDI:高效实现超大单页PDF的自动分块打印

    本文旨在解决将大尺寸单页PDF(如工程图、缝纫图案)切割成多个标准尺寸页面以便打印和重新组装的需求。通过详细介绍如何利用PHP的FPDI库,我们将展示一种纯PDF处理的解决方案,避免了图像转换的开销,实现将原始PDF页面导入并智能平铺到多个输出页面上,从而简化了复杂文档的打印流程。 一、挑战与解决方…

    2025年12月11日
    000
  • PHP PDO日期查询优化:解决DateTime与SQL逻辑运算符使用不当的问题

    本文探讨了在使用PHP PDO进行日期查询时常见的两个问题:DateTime对象初始化不当(使用date()而非”now”)和SQL查询中逻辑运算符&&的错误使用。教程提供了正确的DateTime实例化方法以及将SQL中的&&替换为标准AND的…

    2025年12月11日
    000
  • 提取粘贴值中的首个字符串

    本文旨在提供一种解决方案,通过 JavaScript 和 jQuery 监听 HTML 输入框的粘贴事件,提取粘贴文本中的第一个单词,并将其显示在另一个输入框中。该方法适用于需要从用户粘贴的复杂文本中快速提取关键信息的场景,简化用户操作,提高数据录入效率。 在Web开发中,经常会遇到需要从用户粘贴的…

    2025年12月11日
    000
  • 使用 AJAX 从数据库动态创建 Option Select

    本文将详细介绍在使用 AJAX 从数据库动态生成 选项时,遇到的 NaN 显示问题。通过详细的代码示例,我们将探讨如何正确地从后端获取数据,并在前端动态地构建和添加 元素,从而避免 NaN 错误的出现,并确保下拉选择框能够正确显示数据库中的数据。 在动态表单开发中,经常需要通过 AJAX 从后端获取…

    2025年12月11日
    000
  • 通过按钮传递 PHP 变量到另一页面以获取正确项目

    本文旨在解决如何将一个 PHP 页面中的产品 ID 通过按钮传递到另一个页面,并在目标页面根据该 ID 显示对应的产品信息。文章将深入探讨使用 $_GET 方法传递变量,并提供清晰的代码示例和注意事项,帮助开发者理解和掌握这一常见 Web 开发技巧。 在 Web 开发中,经常需要在不同的页面之间传递…

    2025年12月11日
    000
  • 使用PHP和FPDI实现大型PDF页面分块打印教程

    本教程旨在详细阐述如何使用PHP的FPDI库将大型单页PDF文档(如大幅面图纸或缝纫图案)高效地分割成多个标准尺寸(如Letter或A4)的页面,以便于在普通打印机上分块打印和后续拼接。我们将探讨传统方法的局限性,并重点介绍FPDI如何通过直接导入和精确裁剪PDF内容,避免图像转换的复杂性和潜在质量…

    2025年12月11日
    000
  • 如何配置和管理Web应用中的404页面重定向(以CodeIgniter为例)

    本文详细阐述了在Web应用中处理404“页面未找到”错误的重要性,并以CodeIgniter框架为例,指导读者如何通过配置$route[‘404_override’]实现全局的404页面重定向,将所有不存在的URL请求统一导向指定页面或网站首页。此外,文章还深入探讨了如何针对…

    2025年12月11日
    000
  • 如何处理控制器中不存在的方法并实现特定重定向

    本文详细介绍了在CodeIgniter框架中如何高效管理控制器内不存在的方法请求。首先,我们将探讨全局404页面配置及其局限性,理解为何默认设置可能无法满足特定需求。接着,我们将深入讲解并提供示例代码,演示如何利用CodeIgniter的_remap()方法实现控制器级别的灵活重定向,确保对非定义方…

    2025年12月11日
    000
  • PHP与FPDI:高效拆分大型PDF页面以实现分片打印

    本教程旨在指导如何使用PHP及其FPDI库,将一个大型的单页PDF文件(如超大尺寸的图案或图纸)智能地拆分成多个标准尺寸(如Letter或A4)的PDF页面,以便于在普通打印机上分片打印并重新拼接。文章将详细阐述基于FPDI的直接PDF内容导入与定位技术,避免了传统图像转换方法可能带来的质量损失和文…

    2025年12月11日
    000
  • CodeIgniter控制器中处理不存在的方法并重定向至默认方法

    本文将深入探讨如何在CodeIgniter框架中,针对特定控制器处理用户请求的不存在方法。通过利用CodeIgniter的_remap方法,我们可以灵活地拦截所有方法调用,并实现将无效请求优雅地重定向至控制器的默认index方法,从而避免触发全局404错误,提升用户体验和系统健壮性。 理解CodeI…

    2025年12月11日
    000
  • HTML输入框粘贴内容自动提取首词教程

    本教程旨在详细指导如何在用户向HTML输入框粘贴文本时,通过JavaScript(结合jQuery)自动截取并仅保留粘贴内容中的第一个词。我们将重点介绍如何利用paste事件监听、安全地获取剪贴板数据以及高效处理字符串以实现这一功能,从而确保输入框内容始终符合预设的单词格式要求,提升数据输入的规范性…

    2025年12月11日
    000
  • 如何在表单中动态添加文本输入框

    本文详细介绍了如何利用JavaScript实现网页表单中动态添加文本输入框的功能。通过监听按钮点击事件,结合DOM操作(如document.createElement和element.appendChild),可以灵活地在指定位置创建并插入新的输入字段,并确保每个字段具有唯一的标识,从而提升用户交互…

    2025年12月11日
    000
  • Laravel 视图 404 错误排查:缓存优化与解决方案

    当您在 Laravel 8 中配置了正确的路由、控制器和视图,却仍然遇到 404 Not Found 错误时,这通常是由于 Laravel 的内部缓存机制导致。本文将详细解释这一现象,并提供通过运行 php artisan optimize 命令来清除并重新编译应用缓存的有效解决方案,确保您的视图能…

    2025年12月11日
    000
  • PHP PDO日期查询陷阱与优化:正确处理日期和SQL逻辑操作符

    本教程旨在解决PHP PDO中日期比较不准确的问题,特别是当使用DateTime对象和SQL逻辑操作符时。文章将详细阐述如何正确初始化DateTime对象以获取当前日期,并强调在SQL查询中使用AND而非&&的最佳实践,确保数据检索的准确性和代码的健壮性。 在开发数据库驱动的php应…

    2025年12月11日
    000
  • PDO中日期时间查询与时区处理的实践指南

    本文旨在解决PDO数据库查询中日期时间匹配不准确的问题,特别是当涉及到特定时区和SQL逻辑运算符时。核心内容包括:正确使用DateTime类获取指定时区的当前日期,避免date()函数可能引入的隐式时区问题;以及强调在SQL查询中应使用标准的AND逻辑运算符而非&&,以确保查询的兼容…

    2025年12月11日
    000
  • 配置CodeIgniter全局404页面重定向

    本文将详细介绍如何在CodeIgniter框架中配置自定义的404错误页面重定向机制。通过修改路由配置和实现一个专门的控制器方法,我们可以确保当用户访问不存在的URL或控制器方法时,系统能够自动将其重定向到指定的页面,例如网站的根目录,从而提升用户体验并优化网站的错误处理流程。 理解CodeIgni…

    2025年12月11日
    000

发表回复

登录后才能评论
关注微信