useMediaQuery
响应式 Media Query。 一旦你创建了一个 MediaQueryList 对象,你可以检查查询结果或在结果更改时接收通知。
演示
isLargeScreen: false
prefersDark: false
用法
js
import { useMediaQuery } from '@vueuse/core'
const isLargeScreen = useMediaQuery('(min-width: 1024px)')
const isPreferredDark = useMediaQuery('(prefers-color-scheme: dark)')
服务端渲染和 Nuxt
如果你正在使用启用 SSR 的 useMediaQuery
,那么你需要指定你想要在服务端渲染和在水合之前渲染的屏幕尺寸,以避免水合不匹配
js
import { breakpointsTailwind, useMediaQuery } from '@vueuse/core'
const isLarge = useMediaQuery(
'(min-width: 1024px)',
{ ssrWidth: 768 } // Will enable SSR mode and render like if the screen was 768px wide
)
console.log(isLarge.value) // always false because ssrWidth of 768px is smaller than 1024px
onMounted(() => {
console.log(isLarge.value) // false if screen is smaller than 1024px, true if larger than 1024px
})
或者你可以使用 provideSSRWidth
为你的应用全局设置
类型声明
typescript
/**
* Reactive Media Query.
*
* @see https://vueuse.org.cn/useMediaQuery
* @param query
* @param options
*/
export declare function useMediaQuery(
query: MaybeRefOrGetter<string>,
options?: ConfigurableWindow & {
ssrWidth?: number
},
): ComputedRef<boolean>
源
贡献者
更新日志
v12.8.0
on 3/5/2025v12.5.0
on 1/22/2025v12.3.0
on 1/2/202559f75
- feat(toValue): 弃用 @vueuse/shared 中的 toValue,转而使用 Vue 原生v12.1.0
on 12/22/2024v12.0.0-beta.1
on 11/21/2024v10.3.0
on 7/30/2023v10.0.0-beta.4
on 4/13/20234d757
- feat(types)!: 将 MaybeComputedRef 重命名为 MaybeRefOrGetter10e98
- feat(toRef)!: 将 resolveRef 重命名为 toRefv10.0.0-beta.3
on 4/12/2023