Nuxt开发中The client-side rendered virtual DOM tree is not matching server-rendered content.的问题

在将VueSPA项目改造成Nuxt以优化SEO的过程中,遇到客户端和服务器渲染内容不匹配的错误。排查后发现是由于Van Icon组件导致的问题。解决方法是使用<client-only>包裹该组件,实现客户端渲染,从而消除报错。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

【写在最前面,我的解决方法:用<client-only>把不必要的组件包裹起来】

公司的移动端由于要对SEO做出优化支持,所以项目从普通的Vue spa项目改造为Nuxt;

在改造过程中,发现有“The client-side rendered virtual DOM tree is not matching server-rendered content. This is likely caused by incorrect HTML markup, for example nesting block-level elements inside <p>, or missing <tbody>. Bailing hydration and performing full client-side render.”的报错,很迷茫

通过查询,知道了这是由于一些节点带来的错误,或者是因为在P标签里加入block的元素,或者是缺少了<tbody>;

但代码里是没有出现这种情况的,项目是用Vue +Vant制作的,排查以后发现,是某个组件里用了vany的<<van-icon />;

这种icon没有在服务器渲染的必要,完全可以在客户端渲染,所以用<client-only>把这个组件包裹起来,编译刷新,报错解除!

所以相关问题也可以考虑一下是否是因为类似的原因。

看看我的小程序吧:

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值