前端:用Sass简化媒体查询

在进行媒体查询的编写的时候,我们可以利用scss与与编译器,通过@include混入的方式对代码进行简化,从而大大提高了代码的可维护性,也减少了代码的编写量,废话不多说,直接上代码

css 复制代码
// 定义设备数值
$breakpoints: (
  'phone': (320px, 480px),
  'ipad': (481px, 768px),
  'notebook': (769px, 1024px),
  'pc': 1205px
);

// sass 混合
@mixin respnseTo($breakname) {
  // map-get:从对应键值对中获取数据,
  $bp: map-get($breakpoints, $breakname);

  // 判断 $bp 是 list,还是单个值 
  @if type-of($bp) == 'list' {
    // 从 list 中获取第一项和第二项数据
    $min: nth($bp, 1);
    $max: nth($bp, 2);
    @media (min-width: $min) and (max-width: $max) {
      // @content:混入其他的数据
      @content;
    }
  } @else {
    @media (min-width: $bp) {
      @content;
    }
  };
}

.container {
  width: 100%;

  @include respnseTo('phone') {
    height: 50px;
  }

  @include respnseTo('ipad') {
    height: 60px;
  }
}

最后编译结果:

css 复制代码
@media (min-width: 320px) and (max-width: 480px) {
  .header {
    height: 50px;
  }
}

@media (min-width: 481px) and (max-width: 768px) {
  .header {
    height: 60px;
  }
}
相关推荐
CharlieWang3 分钟前
Vite 终于有了一个很轻的服务端搭档
前端·vite·mcp
new code Boy5 分钟前
Vue3转React速查表
前端·javascript·react.js
@PHARAOH12 分钟前
WHAT - 替代 Express 和 Koa 的现代轻量版 Hono
前端·微服务·express·koa
掘金安东尼20 分钟前
低代码真的能替代前端吗?我看了 RollCode 的设计之后有点新想法
前端
IT_陈寒24 分钟前
JavaScript开发者必知的5个高效调试技巧,比console.log强10倍!
前端·人工智能·后端
亿元程序员27 分钟前
历时100天,亿元Cocos小游戏实战合集顺利完结!!!
前端
恋猫de小郭41 分钟前
Flutter Beta 版本引入 ScrollCacheExtent ,并修复长久存在的 shrinkWrap NaN 问题
android·前端·flutter
Liu.77443 分钟前
vscode前端实用插件
前端·vscode
私人珍藏库1 小时前
[Windows] 媒体人工具箱 MTools v0.0.12
媒体·工具·软件·win·多功能
HWL56791 小时前
使用CSS实现,带有动态浮动高亮效果的导航菜单
前端·css