The client-side rendered virtual DOM tree is not matching server-rendered content(已解决)

使用nuxt.js或者vue.js有时会出现下面的报错:[Vue warn]: The client-side rendered virtual DOM tree is not matching server-rendered content

在这里插入图片描述
浏览器端渲染的DOM树与服务端不匹配。

什么是Bailing hydration?

Vue从服务端接管静态的HTML文件并且把它转换为响应式数据的过程。

如何解决报错?

报错的源代码:

<template>
  <div v-show="!is_mobile" class="align_center">
    <span class="theme_btn" @click="dialogVisible = true">打赏</span>
    <el-dialog
        title="感谢你的支持"
        v-model="dialogVisible"
        width="40%"
        center
        draggable
      >
        <el-row :gutter="20">
          <el-col :span="12" style="text-align: center">
            <img src="~assets/images/wechat.jpeg" alt="wechat">
            <span style="display: block">微信</span>
          </el-col>
          <el-col :span="12" style="text-align: center">
            <img src="~assets/images/alipay.jpeg" alt="wechat">
            <span style="display: block">支付宝</span>
          </el-col>
        </el-row>
      </el-dialog>
  </div>
</template>

原因就是这个渲染过程中导致了服务端和客户端不一样,如果你正在用Nuxt.js,那么使用包裹el-dialog即可解决问题。

<template>
  <div v-show="!is_mobile" class="align_center">
    <span class="theme_btn" @click="dialogVisible = true">打赏</span>
    <ClientOnly>
      <el-dialog
        title="感谢你的支持"
        v-model="dialogVisible"
        width="40%"
        center
        draggable
      >
        <el-row :gutter="20">
          <el-col :span="12" style="text-align: center">
            <img src="~assets/images/wechat.jpeg" alt="wechat">
            <span style="display: block">微信</span>
          </el-col>
          <el-col :span="12" style="text-align: center">
            <img src="~assets/images/alipay.jpeg" alt="wechat">
            <span style="display: block">支付宝</span>
          </el-col>
        </el-row>
      </el-dialog>
    </ClientOnly>
  </div>
</template>

报错消失。

当使用 Cypress 的 `cy.screenshot()` 试图捕捉包含固定定位 (`position: fixed;`) 元素如 `.bportalcomponents-header` 的全屏截图时,由于固定元素脱离了标准文档流,可能导致截图不完整。要解决这个问题,可以尝试以下几种方法: 1. **强制渲染**: 首先确保在截图前触发了所有必要的 JavaScript 动画和 DOM 渲染。使用 `cy.flush()` 或者等待特定事件(比如 `window.onload` 或 `document.rendered`)。 ```javascript cy.get('.bportalcomponents-header').then(() => { cy.document().then(() => cy.viewport(window.innerWidth, window.innerHeight)); cy.wait('window.onload'); // 或其他渲染完成的信号 cy.screenshot(); }); ``` 2. **调整 viewport**: 尝试在截图之前设置viewport大小为屏幕大小,这将包括滚动条和固定位置元素: ```javascript cy.viewport(window.innerWidth, window.innerHeight); cy.screenshot(); ``` 3. **模拟用户交互**: 如果固定元素需要滚动才能看到全部内容,可以尝试滚动到底部再截图: ```javascript cy.get('.bportalcomponents-header').scrollToBottom().then(() => { cy.screenshot(); }); ``` 4. **CSS 工艺**: 可能需要临时修改 CSS 以让固定元素在屏幕范围内,例如移除 `position: fixed` 或调整其 z-index 使其在正常流中显示,然后截图,最后恢复原状。 如果以上方法都无法解决问题,可能需要查看具体页面的实现细节,并考虑是否可以在前端代码层面做出特殊处理,例如禁用固定定位元素的滚动行为,以便于截图。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值