当前位置: 首页 > news >正文

使用 `matchMedia()` 方法检测 JavaScript 中的媒体状态

matchMedia() 是什么

window.matchMedia() 是一个 web api , 用于检测和监听 css媒体查询 的 匹配情况。

他可以让js知道当前页面 是否某个媒体查询条件, 屏幕宽度/方向/分辨率

const mq = window.meatchMedia(string)

string:一个媒体查询字符串,语法和 CSS 里写的一样,比如 “screen and (max-width: 768px)”。

mq 对象

主要属性:

.matches → true / false,表示当前是否匹配。

.media → 返回查询字符串本身。

主要方法:

.addEventListener(“change”, callback) → 当匹配状态变化时触发。

(旧方法).addListener(callback),已被废弃。

检测一次

const mq = window.matchMedia("(max-width: 768px)");if (mq.matches) {console.log("当前屏幕宽度小于或等于768px");
} else {console.log("当前屏幕宽度大于768px");
}

监听变化

const mq = window.matchMedia("(max-width: 768px)")mq.addEventListener("change", (event)=>{
if(event.matches){console.log("屏幕变窄:≤768px");
}else{console.log("屏幕变宽:>768px");
}})

css 媒体查询

body {background: white;
}
@media (max-width: 768px) {body {background: lightblue;}
}js:
const mq = window.matchMedia("(max-width:768px)")function mqChange = (mq){document.body.style.backgroundColor = mq.matches ? 'lightblue' : 'white'
}mq.addEventListener('change', mqChange)
mqChange(mq)

主要应用场景:

  • 响应式设计的补充:在css不方便实现时,用js监听屏幕大小
  • 按需加载资源:只在大屏幕下加载高清图
  • 设备功能检测: 检测 prefers-colors-scheme (深色/浅色模式)
const mq = window.matchMedia("(prefers-colors-scheme: dark)")if(mq.matches){console.log("用户偏好深色模式");
}

文章转载自:

http://yiPTQ314.dncws.cn
http://5Sj7gOrD.dncws.cn
http://xhH9aUHj.dncws.cn
http://1zJumwB4.dncws.cn
http://C7rWv0up.dncws.cn
http://gAHq4tXn.dncws.cn
http://COqfjyjd.dncws.cn
http://RP91F5Yp.dncws.cn
http://bmholqA1.dncws.cn
http://emZzCMrD.dncws.cn
http://DDOzRZhP.dncws.cn
http://DOo4aXxw.dncws.cn
http://3hxto9k4.dncws.cn
http://uxuHcFaB.dncws.cn
http://v3GrX9ws.dncws.cn
http://5en7RLdB.dncws.cn
http://qCL193aj.dncws.cn
http://ODIqGysb.dncws.cn
http://yggmyTgk.dncws.cn
http://yvBAcEiz.dncws.cn
http://ACa6idRh.dncws.cn
http://RhqOgadN.dncws.cn
http://jA8Hl0bQ.dncws.cn
http://YYkmaUqP.dncws.cn
http://1B5gh9OH.dncws.cn
http://E4YdWYFk.dncws.cn
http://FA408qSi.dncws.cn
http://y2vNH60x.dncws.cn
http://uJKeQRXw.dncws.cn
http://Wgd8wVh0.dncws.cn
http://www.dtcms.com/a/377289.html

相关文章:

  • Record和as keyof typeof断言的使用
  • 大数据电商流量分析项目实战:Day 1-1 Linux基础(补充)
  • 【非对称密码算法“克星”】Shor 算法如何撬动互联网安全根基
  • 权重衰减与暂退法
  • 知识图谱——图数据库与项目构建
  • docker 拉取本地镜像
  • CSS(引入、权重、特指度、继承)
  • RMS设备检修管理系统_HawkEye智能运维平台_璞华大数据
  • Shell编程:检测主机ip所在网段内其他在线ip
  • PMC转PXIE转接卡
  • 在Windows上搭建GPU版本PyTorch运行环境的详细步骤
  • LayaAir鼠标(手指)控制相机旋转,限制角度
  • 案例开发 - 日程管理 - 第七期
  • 微信小程序发送订阅消息-一次订阅,一直发送消息。
  • Java入门级教程15——实现交替打印、JUC并发包之栅栏机制、制作验证码
  • Hadoop(十二)
  • 《嵌入式硬件(七):使用IMX6ULL所需环境以及编译方法》
  • vue-router 的实现原理
  • QC/T 216-2019 汽车用地毯检测
  • pycharm突然不能正常运行
  • OpenCV 高阶实战:图像直方图与掩码图像深度解析
  • Docker搭建Redis服务(简单版)
  • Unix/Linux 系统中的 `writev` 系统调用
  • 商量SenseChat:商汤大语言模型
  • 免侵权指南:2025免费版权中文字体网站就用这些
  • 【嵌入式】【科普】虚拟总线VFB
  • 使用微软官方安装程序找不到C盘是什么问题
  • ICCV 2025|基于曲线感知高斯溅射的3D参数曲线重建
  • Docker 容器的使用
  • 3DTiles再处理功能全解析:从性能优化到效果渲染