gpt4 book ai didi

vue.js - [Vue 警告] : The client-side rendered virtual DOM tree is not matching server-rendered content ( Nuxt/Vue/lerna monorepo )

转载 作者:行者123 更新时间:2023-12-05 08:22:36 26 4
gpt4 key购买 nike

我正在尝试运行一个基本的 Nuxt 应用程序,其中包含一个使用 vue-cli 在 lerna monorepo 中构建的外部 Vue 组件。

该页面短暂显示组件内容(服务器呈现),然后消失并抛出以下错误。

"export 'default' (imported as 'Header') was not found in 'a2b-header'

其次是

Mismatching childNodes vs. VNodes: NodeList(7) [svg, text, div#app, text, h2.subtitle, text, div.links] (7) [VNode, VNode, VNode, VNode, VNode, VNode, VNode]

最后是一个红色的 Vue 警告

[Vue warn]: 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.

我为外部组件使用的设置是package.json:

{
"name": "a2b-header",
"version": "0.1.0",
"private": true,
"main": "./dist/a2b-header.umd.js",
"scripts": {
"serve": "vue-cli-service serve",
"build": "vue-cli-service build --target lib --name a2b-header src/main.js",
"lint": "vue-cli-service lint"
},
"dependencies": {
"core-js": "^3.4.3",
"vue": "^2.6.10"
},
...
}

我的 ma​​in.js 如下所示:

import Header from './Header.vue'

export default Header

和组件文件本身 Header.vue 是:

<template>
<div id="app">
<h1>Welcome to Your Vue.js App</h1>
</div>
</template>

<script>
export default {
name: 'Header'
}
</script>

<style>
#app {
font-family: 'Avenir', Helvetica, Arial, sans-serif;
text-align: center;
color: #2c3e50;
margin-top: 60px;
}
</style>

所有内容都使用简单的方式导入到 Nuxt 项目 index.vue 中:

import Header from 'a2b-header'

而且....它不起作用。我认为 SSR 与客户端的不匹配与不正确的导出有关,可能可以通过某些 webpack 配置解决,但在尝试了许多不同的事情之后,我在这里苦苦挣扎。

我想让它运行的原因是,在 monorepo 中,我们计划拥有各种 Vue 应用程序(包括 SPA 和 Nuxt),并且将通用代码封装在可跨不同项目重用的组件中的能力至关重要。

最佳答案

<ClientOnly> <YourComponent> </ClientOnly> 包裹你的组件

前往官方 nuxt 文档了解更多信息:

https://nuxtjs.org/docs/2.x/features/nuxt-components#the-client-only-component

关于vue.js - [Vue 警告] : The client-side rendered virtual DOM tree is not matching server-rendered content ( Nuxt/Vue/lerna monorepo ),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59994004/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com