V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
MorningStar0
V2EX  ›  程序员

说几点个人使用 nextjs 的感受

  •  
  •   MorningStar0 · 31 天前 · 5130 次点击

    网页: https://freezer-home.ashesborn.cloud/ 仓库: https://github.com/sadofriod/freezer-home

    部署角度

    目前体验基本满分。结合 vercel 基本不用任何配置,就能快速部署。并且使用 cloudflare 的域名后,也可以实现让国内访问。

    开发体验角度

    无法在 server component 里直接使用 hooks ,ref 和 react 的事件收集( onChange 这类)的功能,所以有些动画需要原生实现,失去了 react 的很多便利性。

    SEO 角度

    由于可以将大部分内容直接通过静态页面返回,所以确实带来了巨大的提升。但是官方文档对于 robots ,sitemap ,meta 标签的 keywords 之类的常见功能没有提供一个比较好的解决方案(目前还是采用字符串模版拼接的方式,或者是我没仔细看),理想的情况下希望能提供几个函数来收集每个路由下的信息来解决这个问题。

    监控工具的集成角度

    目前我集成了 google analytics 、tag manager 、google 站长工具。官方提供了一个集成的 component 配置比较简单。

    server 负载角度

    对于大部分网页访问量不高的情况不会有问题,但虽然提供了 server component 的渲染缓存,但对于接入数据的变动 server component 来说,还是存在部分 CPU 密集型的计算在 nodejs 的 server 中,在访问量比较大的时候,还是需要考虑。

    总结

    总的来说,对于我个人来讲,如果没有强烈的 SEO 需求,对于一般项目的话不会采用 nextjs 。server component 和 client component 的分离,迫使我在状态管理上要做更多思考和操作。而且对于首屏的渲染在现在协商缓存的基础下,也只有用户收到新版本的网页的时候会有差距,其他大部分情况下差距不大。

    53 条回复    2025-01-16 17:02:57 +08:00
    tpxcer
        1
    tpxcer  
       31 天前
    那你的描述似乎 NUXT 比较舒服些。
    zsj1029
        2
    zsj1029  
       31 天前 via iPhone
    Astro 试试
    lavard
        3
    lavard  
       31 天前   ❤️ 4
    生态为王,nextjs + tailwindcss + shadcn/ui 这套太能打了,太适合目前的 AI 时代了,很多产品只要描述下就能生成。就是 React 19 大改了, 很多第三方库还没跟上,用 next15 又上 React 19 又有点尴尬 , 开发体验还没那么快升上去,等周边生态吧。
    MorningStar0
        4
    MorningStar0  
    OP
       31 天前
    @tpxcer 因为一直是 react 生态 nuxt 还没体验过
    MorningStar0
        5
    MorningStar0  
    OP
       31 天前
    @zsj1029 之前用过,怎么说呢,感觉开发体验有点原始
    MorningStar0
        6
    MorningStar0  
    OP
       31 天前
    @lavard 我是使用 MUI( https://mui.com/)这个库了,而且总感觉 css in js 比 tailwindcss 更适合 JSX 这种情况😂
    snowlee
        7
    snowlee  
       31 天前
    开发体验确实不太行,热更新慢而且老报错

    如果不是考虑 SSR 还是用 Vite 开发舒服,生态完全可以自己选择,Vite + tailwindcss + shadcn/u,

    或者 Vite + mui or antd+ styled-compoents 都不错
    MorningStar0
        8
    MorningStar0  
    OP
       31 天前
    @snowlee 我用 v15 ,现在在创建项目的时候可选 turbopack 了,所以热更新还挺快的。
    snowlee
        9
    snowlee  
       31 天前
    @MorningStar0 #8 15 确实没太了解。https://www.snowlee.site/ 我的博客是 13 搭建的,基本加个新页面就要重新启动,然后热更新真的比 vite 慢好多好多
    Frankcox
        10
    Frankcox  
       31 天前
    我是 SRE ,目前也刚刚开始自学 React 和 Next.js ,现在有个问题想请教下,React Next.js 开发时是需要明确区分服务端组件还是客户端组件吗?这些一般都是在设计的时候根据数据情况来进行区分吗?
    MorningStar0
        11
    MorningStar0  
    OP
       31 天前
    @Frankcox 是的,在 server component 中是无法使用 useEffect 和 useState 这些常用 hook 的。如果当前组件是 client component 需要在文件最顶部声明。
    jun0205
        12
    jun0205  
       31 天前
    觉得 nextjs 除了 api 比较好用,其它的算是把前端开发都变复杂了,然后开发环境是真慢,用 nextjs 主要还是为了使用 vercel
    cwliang
        13
    cwliang  
       31 天前
    用过一段时间,体验不是很舒服,如果不考虑 SEO ,我是不会用这玩意的。
    13=>14=>15 每个版本变动很大,需要重新看文档。文档比较杂,同一个东西能看到好几种使用姿势。还有那个 NextAuth ,简直就是一坨。跑起来很吃内存,如果有内存泄漏问题,需要很强的 node.js 功底去排查,用起来成本挺高的
    9ki
        14
    9ki  
       31 天前
    不喜欢 next.js 的一个重要原因是它的脚手架又重又难用, 和基于 vite 的一堆 ssr 框架相比体验差太远了
    witcan
        15
    witcan  
       31 天前
    为什么我用最新版的 nextjs ,什么都不改,构建生产文件就报错,不知道是不是姿势不对
    fescover
        16
    fescover  
       31 天前
    试试 react-router v7, 一个框架集齐 spa, ssr, ssg
    https://reactrouter.com/home

    搭配 trpc, 全栈开发体验丝滑
    https://github.com/SteveSuv/remix-t3-stack
    monkeyWie
        17
    monkeyWie  
       31 天前
    我用 nextjs 不用它的 SSR ,我还是前后端分离,build 出来的静态文件放 CDN ,这样感觉最完美
    zhengfan2016
        18
    zhengfan2016  
       31 天前   ❤️ 1
    公司主用框架就是 nextjs ,实话说我觉得 op 对 nextjs 很大概率仅存于业余上的使用或者就不是专业的 react 前端,才能得出 server component 不好用的结论。server 组件优势就是可以把一些内容移到水合前就填充进白纸 html 里,加快首屏渲染速度。至于 hooks ,你完全可以分离拆组件,而且 nextjs 允许你客户端和服务端组件相互嵌套,你只要不通过 props 传递 JSX 就可以,其实是有一丢丢像 astro 的岛,每个客户端组件就是一个岛

    推荐阅读国外其他前端 er 对 react 服务端的帖子: https://www.joshwcomeau.com/react/server-components/

    我是工作经验 1.5 年的 react 前端,如果你工作年限比我大,那么你说得对😁
    MorningStar0
        19
    MorningStar0  
    OP
       31 天前
    @zhengfan2016 不好评价 可以看看我 blog
    zhwithsweet
        20
    zhwithsweet  
       31 天前
    无所谓,我全都要 https://github.com/fisand/f3-app
    zhwithsweet
        21
    zhwithsweet  
       31 天前
    MorningStar0
        22
    MorningStar0  
    OP
       31 天前
    luvsic
        23
    luvsic  
       31 天前
    @zhengfan2016 #18
    我也觉得 Next.js App router 的心智负担大,https://qwik.dev/ 的代码更好理解
    Plumbiu
        24
    Plumbiu  
       31 天前
    @zhengfan2016 我觉得你也有误解,客户端和服务端是不能传递函数,不是不能传递 JSX ,你话说的范围缩小了
    yeluowjz
        25
    yeluowjz  
       31 天前
    @cwliang 解析富文本的 json 数据,递归生成节点树的时候,图片类型用了 Image 组件,结果就内存泄漏了
    zhengfan2016
        26
    zhengfan2016  
       31 天前
    @Plumbiu 你说得对,确实是不能传递函数,这个我打错了
    ZZ74
        27
    ZZ74  
       31 天前 via Android
    @zhengfan2016 和 jsp 一样的.... 好不好用看项目。但是 jsp 被淘汰也是值得吸取的教训
    fyxtc
        28
    fyxtc  
       31 天前
    我去年用 13 写了个项目,然后今年又用 15 写了个项目,重新看 app router 概念,刚看的那时觉得很恶心,为什么变化这么大,用过了其实就还好。还有就是 server 里用 client hooks 很容易,直接把变化的部分抽成 client 就好了。整体来说新版适应后还是更舒服,数据交互写起来爽很多,不用像 13 一样到处都是 swr 和判断 loading ,直接在 server 里 db 出来就好了,用过了就回不去了
    zhjrcc
        29
    zhjrcc  
       31 天前   ❤️ 1
    感觉 OP 这种贴真挺好的,有经验的前辈可以讨论,然后我们有一些在学习的也能从你们的讨论中得到一些知识~~
    SkywalkerJi
        30
    SkywalkerJi  
       31 天前 via Android
    @lavard 现在对 ai 适配最好的就是 next 吗
    shiny
        31
    shiny  
       31 天前
    sitemap.xml 、robots.txt 、meta 自带了一些方案,如 generateSitemaps, generateMetadata, robots.ts ,我感觉还挺好用的
    OneNewLife
        32
    OneNewLife  
       31 天前
    12 以前我给满分,从 13 开始一直是负增长。。。
    XTTX
        33
    XTTX  
       31 天前
    用 1.5 年的经验去评价别人对一个栈的理解业余, 这事本身就很业余。
    1. 是不是真的快
    2. 快多少
    3. 服务器需要增加多少费用
    4. 增加的心智负担
    5. 增加的复杂程度
    6. 增加的接手成本

    这是取舍题。

    sitemap, OG gen, meta 都有不用 ssr 的方案, 而且 SEO 早就不是问题了,2024 了 google 也不至于这么落后。
    gogozs
        34
    gogozs  
       31 天前 via Android
    如果公司组织架构本身就前后端分离,你用 rsc 也没多大意义,一个接口请求慢,你这边本身也做不了什么事情。如果在 layout 做 rsc ,rsc 调接口,甚至每个页面返回都变慢。

    如果全栈,那接口慢就自己直接改造了,那还是很爽的。关键还是你得按照 next js 想要的方式写就很爽,如果还是前后端分离,那是自己给自己找麻烦。

    再补充一个点,router.push 后,useSearchParam() 更新还得过一次服务端,然后客户端组件就会可能用到旧参数渲染。
    MorningStar0
        35
    MorningStar0  
    OP
       31 天前
    @shiny 我看了官方的这些例子,正如我描述的,这种维护字符串模版的模式还是没有达到我的预期。如果能自动通过路由收集生成 sitemap ,然后类似用‘use client’或者注释的方式来提供 robots 和 meta ,这是我希望它能达到的效果。
    XCFOX
        36
    XCFOX  
       31 天前   ❤️ 4
    React Server Component 在我看来不是一个好的设计,为了解决一个简单问题的问题引入了更多概念和复杂度。

    最初 RSC 要解决的简单问题是:在服务端渲染时如何请求数据?
    由于 React hooks 令人费解的设计哲学,React 传统组件无法异步。在客户端渲染时,一般通过 `useEffect` 来获取数据。而在服务端渲染时,我们无法使用 `useEffect`,这使得在服务端请求数据(以及其他异步操作)成为了一个问题。顺带一提,vue3(nuxt.js) 就不会面临这个问题,因为 vue3 的组合式 API 没有 React hooks 的一堆限制,并且 setup 是能够异步的。

    Next.js(RSC)给出的答案是:设计一个全新的服务端组件,专门用来在服务端发请求。好处是,这个组件可以异步了,坏处是,在这个组件中无法使用 hooks 。
    Remix(React-Router-v7)的答案是:Loader 。预先定义好要加载的数据,框架会在数据加载完后将数据注入到组件中。

    在我看来 Loader 方案明显比 RSC 更好:

    1. 性能更好:Loader 单次加载完成页面所有数据; RSC 每次加载一个组件,加载完父组件的数据,再加载子组件的数据。
    2. 更低的心智负担:Loader 只需要提前写好请求,然后方便地通过 useLoaderData 拿到数据; RSC 则引入了额外的服务端组件的概念,在编写时得区分是否为服务端组件,还得到处写 "use client"。

    包括新出的 TanStack 也是提倡使用 Loader 方案而不是 RSC 。

    参考:
    https://react.dev/blog/2020/12/21/data-fetching-with-react-server-components
    https://nuxt.com/docs/getting-started/data-fetching
    https://remix.run/docs/en/main/discussion/data-flow
    https://tanstack.com/router/latest/docs/framework/react/guide/data-loading
    XTTX
        37
    XTTX  
       31 天前
    @MorningStar0 sitemap 生成自己写 https://github.com/supabase/supabase/blob/master/apps/www/internals/generate-sitemap.mjs 每个网站的需求都不一样, 很多需要读 mdx , 有些 url 又需要过滤掉。package.json 里 写个 postbuild, 指向这个 script 就行了。
    MHPSY
        38
    MHPSY  
       31 天前
    @XCFOX 点赞了,你的想法跟我几乎一摸一样,我也写过 nuxt next remix

    next 我最不想去适应的一点就是 hook 不能写在服务端组件里面。

    nuxt 就很正常,useFetch 常规情况下都很好用

    remix 更不用说了,几乎是命令式的请求,也不用操心那么多东西,甚至是服务端为主。
    guotie
        39
    guotie  
       30 天前
    remix 看起来确实是 nice
    zbowen66
        40
    zbowen66  
       30 天前
    @MorningStar0 #8 听说 turbopack bug 多
    zbowen66
        41
    zbowen66  
       30 天前
    热更新巨慢,像回到 webpack 刚问世的时候。

    server component 我主观上觉得巨难受,无数次从 server side props 改成 client side state ,还有玄学的缓存问题。到最后全部都是 use client 。

    next-auth 也非常黑盒,登录成功的响应竟然是 302 ,死活无法适配另一个 web app 。

    对我来说唯一好的体验就是 server actions ,免掉了各种类型定义,不知道其他框架有没有。
    zbowen66
        42
    zbowen66  
       30 天前
    @zbowen66 #41 next-auth 那个我试过配置取消重定向,结果就是带来其他 bug ,拆东墙补西墙。
    MorningStar0
        43
    MorningStar0  
    OP
       30 天前
    @zbowen66 我看过一些评论慢的情况是全量引入了一整个 icons 库,从这点来看可能 turbopackage 对于这种情况没有做好处理
    PPPaul
        44
    PPPaul  
       30 天前 via iPhone   ❤️ 1
    不在 vercel 部署而自行部署你会很难受,他的 nodejs 运行时不是标准运行时,你往中间件里加 feature 难受的一批。和自己的云平台绑的太深了,谨慎考虑吧
    Plumbiu
        45
    Plumbiu  
       30 天前
    @XCFOX 服务端渲染,直接用 fetch 就行了,为什么要用 useEffect ,不太理解,而且 next.js 最开始也是 loader 思想的,参考 page router 里的 getServerSideProps
    baiwfg2
        46
    baiwfg2  
       30 天前
    各位前端大佬,本菜鸟刚学了 nextjs 官方的 dashboard 例子,还看不懂你们讨论的是啥细节。还要补充哪些知识点呢
    chesha1
        47
    chesha1  
       30 天前
    @lavard #3 shadcn/ui 写一些简单应用还行,但是组件毕竟不如 mui ,antd 丰富,感觉还是不太好用。看上去给了本地的源代码可以编辑,但是真的缺什么功能的话,如果依赖的底层组件没有直接给相关接口,自己写很麻烦
    wowbaby
        48
    wowbaby  
       30 天前
    ssr 用起来就是蛋疼,我宁愿用其它语言 mvc 模式实现多好,有研究 ssr 的时间,我代码都写完了,问题又多,关键性能还差,反正是不想再用了。
    xavierchow
        49
    xavierchow  
       30 天前
    @zbowen66
    > next-auth 也非常黑盒,登录成功的响应竟然是 302 ,死活无法适配另一个 web app 。

    next-auth 黑盒说不上,就是文档太差了,我遇到问题都是直接翻源码,它因为要适配各种情况,配置的确比较杂,像重定向之类 redirectTo 如果没有传,它会返回一个 response 就不给你做重定向了。
    frank42a
        50
    frank42a  
       27 天前
    用这个吧 [Eleventy]( https://www.11ty.dev/) 回归质朴
    azhong123
        51
    azhong123  
       6 天前
    @monkeyWie 这种情况下用 nextjs 的目的是啥? 我是写后端的,我的想法和你差不多,然后我主要是感觉用 nextjs 的约定俗成的配置,比如 app 路由,省去我学习其他路由库的时间,不知道你是什么想法
    monkeyWie
        52
    monkeyWie  
       6 天前
    @azhong123 想法跟你差不多,还要个最主要的点是除了 create-t3 之外,没有一个好用的全栈 ts 前后端分离开发脚手架,然而 create-t3 只支持 nextjs ,后来我捣鼓了下变成了开发环境下是 SSR ,只用启动一个服务就能调试前后端,生产环境打包分别部署前后端,体验非常好
    azhong123
        53
    azhong123  
       4 天前
    @monkeyWie #52 孤陋寡闻了,我都没听过 create-t3
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5408 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 31ms · UTC 01:23 · PVG 09:23 · LAX 17:23 · JFK 20:23
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.