最近在團隊中落地React Native 新架構全面落地,積累了不少經驗。整理出來供參考,希望對做類似工作的同學有所幫助。
核心概念
在這個基礎上,我們可以進一步最佳化:
javascript
import { useReducer, useCallback } from 'react'
const initialState = { items: [], filter: '', sort: 'date' }
function reducer(state, action) {
switch (action.type) {
case 'SET_ITEMS': return { ...state, items: action.payload }
case 'SET_FILTER': return { ...state, filter: action.payload }
case 'ADD_ITEM': return { ...state, items: [...state.items, action.payload] }
case 'REMOVE_ITEM': return { ...state, items: state.items.filter(i => i.id !== action.payload) }
default: throw new Error(`Unknown: ${action.type}`)
}
}
這種模式在大型專案中非常實用,能顯著降低維護成本。
深度解析
實際專案中的用法會更復雜一些:
javascript
import { useState, useEffect, useCallback } from 'react'
function DataList({ endpoint, pageSize = 20 }) {
const [data, setData] = useState([])
const [page, setPage] = useState(1)
const [loading, setLoading] = useState(false)
const fetchData = useCallback(async () => {
setLoading(true)
try {
const res = await fetch(`${endpoint}?page=${page}&size=${pageSize}`)
setData(await res.json())
} finally { setLoading(false) }
}, [endpoint, page, pageSize])
useEffect(() => { fetchData() }, [fetchData])
return <div>{loading ? <Spinner /> : <List items={data} />}</div>
}
通過這種方式,程式碼的可測試性和可擴充套件性都得到了提升。
落地經驗
以下是一個完整的示例:
javascript
import React, { useState, useCallback } from 'react'
import { View, Text, FlatList, TouchableOpacity, StyleSheet } from 'react-native'
const ItemList = ({ data, onRefresh }) => {
const [refreshing, setRefreshing] = useState(false)
const handleRefresh = useCallback(async () => {
setRefreshing(true)
await onRefresh()
setRefreshing(false)
}, [onRefresh])
const renderItem = useCallback(({ item }) => (
<TouchableOpacity style={styles.item}>
<Text style={styles.title}>{item.title}</Text>
</TouchableOpacity>
), [])
return (
<FlatList data={data} renderItem={renderItem}
keyExtractor={item => item.id}
refreshing={refreshing} onRefresh={handleRefresh} />
)
}
注意邊界條件處理,這在生產環境中至關重要。
調優策略
關鍵在於理解核心邏輯:
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 { useReducer, useCallback } from 'react'
const initialState = { items: [], filter: '', sort: 'date' }
function reducer(state, action) {
switch (action.type) {
case 'SET_ITEMS': return { ...state, items: action.payload }
case 'SET_FILTER': return { ...state, filter: action.payload }
case 'ADD_ITEM': return { ...state, items: [...state.items, action.payload] }
case 'REMOVE_ITEM': return { ...state, items: state.items.filter(i => i.id !== action.payload) }
default: throw new Error(`Unknown: ${action.type}`)
}
}
這套方案已經在線上穩定運行了半年以上,經過了實際驗證。
小結
- 不要為了用新技術而用新技術
- 程式碼示例僅供參考,需根據業務場景調整
- React Native 新架構全面落地不是銀彈,需要根據專案規模和技術棧選擇
- 理解底層原理比記住 API 更重要