mirror of
https://github.com/yyhuni/xingrin.git
synced 2026-02-03 13:13:10 +08:00
21 lines
618 B
TypeScript
21 lines
618 B
TypeScript
import * as React from "react"
|
||
|
||
const MOBILE_BREAKPOINT = 768
|
||
|
||
export function useIsMobile() {
|
||
// 初始值设为 false,确保 SSR 和客户端初始渲染一致
|
||
const [isMobile, setIsMobile] = React.useState<boolean>(false)
|
||
|
||
React.useEffect(() => {
|
||
const mql = window.matchMedia(`(max-width: ${MOBILE_BREAKPOINT - 1}px)`)
|
||
const onChange = () => {
|
||
setIsMobile(window.innerWidth < MOBILE_BREAKPOINT)
|
||
}
|
||
mql.addEventListener("change", onChange)
|
||
setIsMobile(window.innerWidth < MOBILE_BREAKPOINT)
|
||
return () => mql.removeEventListener("change", onChange)
|
||
}, [])
|
||
|
||
return isMobile
|
||
}
|