使用@import结合媒体查询可实现样式表的按需加载,如@import url("mobile-layout.css") only screen and (max-width: 767px);仅在小屏幕时加载,从而减少不必要的资源下载,提升初始渲染性能,适用于移动、打印和主题等场景,但需注意其必须位于CSS文件开头且会阻塞渲染,推荐关键资源改用HTML中的以获得更好性能。

在CSS中使用@import引入样式表时,可以通过媒体查询实现延迟加载或按需加载,从而优化页面初始渲染性能。这种方式能让某些样式表仅在满足特定条件(如屏幕尺寸、设备类型)时才下载和应用。
使用媒体查询控制@import的加载时机
@import支持在导入样式时指定媒体查询,浏览器会根据当前环境判断是否需要下载该资源。如果媒体条件不匹配,样式表将不会被下载,从而实现“延迟”或“按需”加载的效果。
语法格式如下:
@import url("style-mobile.css") screen and (max-width: 768px);@import url("print.css") print;
@import url("dark-theme.css") (prefers-color-scheme: dark);
说明与建议:
立即学习“前端免费学习笔记(深入)”;
- 只有当用户的设备匹配指定媒体类型或表达式时,对应的CSS文件才会被加载
- 常用于针对移动设备、打印场景或深色模式单独加载样式
- 可有效减少桌面端用户加载移动端专用样式的开销
实际应用场景示例
以下是一个响应式网站中按需加载移动样式的例子:
@import url("mobile-layout.css") only screen and (max-width: 767px);@import url("desktop-widgets.css") only screen and (min-width: 768px);
在这个例子中:
- 小屏幕设备只会加载
mobile-layout.css - 桌面设备跳过移动端样式,只请求
desktop-widgets.css - 避免了所有用户都下载完整样式包的问题
注意事项与性能提示
虽然@import结合媒体查询能实现条件加载,但仍有几点需要注意:
-
位置要求:所有
@import规则必须出现在CSS文件的开头,在其他规则之前 -
性能权衡:
@import会阻塞渲染,且无法像那样设置rel="preload"提前预加载 -
推荐替代方案:对于关键路径上的资源,建议使用HTML中的
实现更高效的按需加载 -
兼容性良好:现代浏览器均支持带媒体查询的
@import,但在极端老旧版本中可能存在解析延迟
基本上就这些。合理利用媒体查询配合@import,可以在不增加主文档复杂度的前提下实现基础的样式按需加载。










