被 NoSSR 包裹的内容在服务端不会进行渲染,在客户端 hydrate 阶段也不会渲染,等到整个 App 渲染完成后便会立即渲染。
下列代码中,Time
组件用于展示当前的时间,由于服务端渲染和客户端 hydrate 时获取到的时间是不一致的,React 就会抛出异常。针对这种情况可以使用 NoSSR
进行优化:
在 CSR 中,常常需要根据当前浏览器 UA,或是当前页面 URL 的某个参数的不同,来渲染不同的内容。如果此时应用直接切换到 SSR,很有可能出现不符合预期的结果。
Modern.js 在 SSR 上下文中提供了完整的浏览器端信息,可以利用上下文信息来决定组件在服务端的渲染结果。
即便如此,如果应用里有太多的判断,开发者希望以后再使用上下文,或者不希望某些内容在服务端被渲染,可以使用 NoSSR 组件将这一部分剔除在服务端渲染外。