定位 vue ssr DOM 不匹配的报错
nuxt 使用过程中报错,错误信息如下:
1 | [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. |
给的错误信息很全,关键是如何定位。这里给出一种方案(基于 Chrome 浏览器):
- 按
F12
打开控制台,然后重载报错页面 - 在控制台找到该错误位置,点击错误信息右边的定位链接跳转到错误代码行并在此打个断点
data:image/s3,"s3://crabby-images/0e81f/0e81f8471535cbafa029f83eba64a42976eef19e" alt="step 2"
- 重载报错页面进入断点,将鼠标移到变量
msg
上,确定是否为当前的错误
data:image/s3,"s3://crabby-images/b2343/b23435fa2045c9883b09eb62e314c530597012f9" alt="step 3"
- 在调用堆栈(Call Stack)中点击
patch
,浏览器会自动定位至新的调用栈,将鼠标移至光标上方第四行的hydrate
方法上,然后点击弹出信息框右上角的链接进入hydrate
方法内部,找到光标下方的第 14 行return false
的地方,打个断点,把其他断点移除
data:image/s3,"s3://crabby-images/5daa4/5daa4324061ec0bc86113bcd8f198803c4c9db52" alt="step 4"
- 再次重载页面进入断点,这时可以将
elm
变量打印出来,elm
就是导致报错的元素
data:image/s3,"s3://crabby-images/6fc1e/6fc1e3442539f9ea5dcc5318bbfdc705425b244b" alt="step 5"