CSS前瞻:@media (scripting)助你优雅降级

你能想象在CSS里判断JavaScript有没有被禁用吗?现在,CSS整活了,通过 @media (scripting) 特性,开发者就可以判断当前环境JavaScript的可用性。

@media 查询简介

在介绍 @media (scripting) 之前,先给新来的同学简单介绍一下 @media 查询。
@media 查询是响应式设计的核心,它允许开发者编写针对不同媒体类型(如屏幕、打印)和条件(如视口宽度、分辨率)的样式,例如:

css 复制代码
/* 默认样式,适用于大屏幕 */
.container {
  width: 60%;
  margin: auto;
}

/* 屏幕宽度小于600像素时应用的样式 */
@media screen and (max-width: 600px) {
  .container {
    width: 100%;
    margin: 0;
  }
}

比较少见的是把@media 查询用于调整打印样式。在打印网页时,可以定义特定的 CSS 规则以优化页面的打印布局,如去除背景颜色和图像,更改字体大小和颜色,以及隐藏对于打印不必要的元素。

css 复制代码
/* 在屏幕上显示时使用的样式 */
body {
  background-color: lightblue;
  color: black;
}

/* 添加一些屏幕专用的样式 */
.navbar, .footer {
  display: block;
}

/* 当文档被打印时使用的样式 */
@media print {
  body {
    background-color: white;
    color: black;
  }

  /* 隐藏屏幕专用的元素 */
  .navbar, .footer {
    display: none;
  }
}

在这个例子中:

  • 当网页在屏幕上显示时,它有一个浅蓝色的背景和黑色的文字。
  • 当网页被打印时(或保存为 PDF),背景变为白色,文字保持黑色,同时导航栏和页脚被隐藏,因为这些元素通常在打印版本中不需要显示。

@media (scripting) 特性

@media (scripting) 是CSS3新发布的媒体查询特性,它允许开发者基于客户端脚本(如 JavaScript)的支持情况来应用不同的样式。

这个特性主要有三个值:

  • none 表示不支持脚本
  • initial-only 表示仅在页面加载时执行脚本
  • enabled 则表示脚本完全可用

应用场景

  • 禁用脚本的网页:为那些因为辅助技术或安全设置禁用JavaScript的用户提供替代样式。
  • 渐进增强:为不支持脚本的浏览器进行样式降级。
  • 广告和追踪阻止:对于使用广告拦截器的用户,提供不依赖于脚本的内容和布局。

使用示例

考虑一个动态内容加载区域,它依赖于JavaScript。在不支持脚本的环境中,我们可以使用 @media (scripting: none) 提供一个备选的静态内容显示或友好的消息提示。以下是代码示例:

css 复制代码
.dynamic-content {
  color: blue;
  /* 其他样式 */
}

@media (scripting: none) {
  .dynamic-content {
    color: gray;
    text-decoration: line-through;
    /* 其他备选样式 */
  }
}

结语

你问兼容性?额......年轻人,我们聊下一个话题吧

相关推荐
清汤饺子5 小时前
OpenClaw 本地部署教程 - 从 0 到 1 跑通你的第一只龙虾
前端·javascript·vibecoding
爱吃的小肥羊7 小时前
比 Claude Code 便宜一半!Codex 国内部署使用教程,三种方法任选一!
前端
IT_陈寒9 小时前
SpringBoot项目启动慢?5个技巧让你的应用秒级响应!
前端·人工智能·后端
树上有只程序猿9 小时前
2026低代码选型指南,主流低代码开发平台排名出炉
前端·后端
橙某人9 小时前
LogicFlow 小地图性能优化:从「实时克隆」到「占位缩略块」!🚀
前端·javascript·vue.js
高端章鱼哥10 小时前
为什么说用OpenClaw对打工人来说“不划算”
前端·后端
大脸怪10 小时前
告别 F12!前端开发者必备:一键管理 localStorage / Cookie / SessionStorage 神器
前端·后端·浏览器
Mr_Mao10 小时前
我受够了混乱的 API 代码,所以我写了个框架
前端·api
小徐_233310 小时前
向日葵 x AI:把远程控制封装成 MCP,让 AI 替我远程控制设备
前端·人工智能
冴羽10 小时前
来自顶级大佬 TypeScript 之父的 7 个启示
前端·typescript