Skip to content
⚠️ This article was written in 2021. Some content may be outdated.

React 18 Suspense SSR 流式渲染

在日常開發中,React 18 Suspense SSR 流式渲染的使用頻率越來越高。本文系統地講解其用法、原理和最佳化策略。

快速上手

我們可以通過以下方式來改進:

javascript
import { useRef, useEffect, useState } from 'react'

function useIntersectionObserver(options = {}) {
  const [isVisible, setIsVisible] = useState(false)
  const ref = useRef(null)

  useEffect(() => {
    const observer = new IntersectionObserver(([entry]) => {
      setIsVisible(entry.isIntersecting)
    }, { threshold: 0.1, ...options })
    const el = ref.current
    if (el) observer.observe(el)
    return () => { if (el) observer.unobserve(el) }
  }, [])

  return [ref, isVisible]
}

這套方案已經在線上穩定運行了半年以上,經過了實際驗證。

內部原理

先來看基本的實現方式:

javascript
import { useRef, useEffect, useState } from 'react'

function useIntersectionObserver(options = {}) {
  const [isVisible, setIsVisible] = useState(false)
  const ref = useRef(null)

  useEffect(() => {
    const observer = new IntersectionObserver(([entry]) => {
      setIsVisible(entry.isIntersecting)
    }, { threshold: 0.1, ...options })
    const el = ref.current
    if (el) observer.observe(el)
    return () => { if (el) observer.unobserve(el) }
  }, [])

  return [ref, isVisible]
}

這段程式碼展示了基本的使用方式。實際專案中還需要考慮錯誤處理和邊界條件。

業務實戰

在這個基礎上,我們可以進一步最佳化:

javascript
import { useRef, useEffect, useState } from 'react'

function useIntersectionObserver(options = {}) {
  const [isVisible, setIsVisible] = useState(false)
  const ref = useRef(null)

  useEffect(() => {
    const observer = new IntersectionObserver(([entry]) => {
      setIsVisible(entry.isIntersecting)
    }, { threshold: 0.1, ...options })
    const el = ref.current
    if (el) observer.observe(el)
    return () => { if (el) observer.unobserve(el) }
  }, [])

  return [ref, isVisible]
}

這種模式在大型專案中非常實用,能顯著降低維護成本。

效能對比

實際專案中的用法會更復雜一些:

javascript
import { useRef, useEffect, useState } from 'react'

function useIntersectionObserver(options = {}) {
  const [isVisible, setIsVisible] = useState(false)
  const ref = useRef(null)

  useEffect(() => {
    const observer = new IntersectionObserver(([entry]) => {
      setIsVisible(entry.isIntersecting)
    }, { threshold: 0.1, ...options })
    const el = ref.current
    if (el) observer.observe(el)
    return () => { if (el) observer.unobserve(el) }
  }, [])

  return [ref, isVisible]
}

通過這種方式,程式碼的可測試性和可擴充套件性都得到了提升。

問題排查

以下是一個完整的示例:

javascript
import { useRef, useEffect, useState } from 'react'

function useIntersectionObserver(options = {}) {
  const [isVisible, setIsVisible] = useState(false)
  const ref = useRef(null)

  useEffect(() => {
    const observer = new IntersectionObserver(([entry]) => {
      setIsVisible(entry.isIntersecting)
    }, { threshold: 0.1, ...options })
    const el = ref.current
    if (el) observer.observe(el)
    return () => { if (el) observer.unobserve(el) }
  }, [])

  return [ref, isVisible]
}

注意邊界條件處理,這在生產環境中至關重要。

小結

  • React 18 Suspense SSR 流式渲染不是銀彈,需要根據專案規模和技術棧選擇
  • 理解底層原理比記住 API 更重要
  • 生產環境使用前務必做好相容性驗證
  • 團隊協作中約定和文件比技術本身更重要
  • 關注社群動態,技術方案需要持續迭代

MIT Licensed