这一节,我们来讲规矩,谈网格,做人可以不要脸,不讲规矩,不讲道理(特指傲娇兽),但底线还是要有的,如同网格一样,不能超出。
这里我们别人封装好的模块,不过呢,我们也会详细介绍一下原理。首先我们安装以下 jeet 框架
npm install --save jeet
这个 jeet 框架有 scss 和 stylus 两个版本。核心不大,只有 3 个文件。在 _settings.scss 里面初始化了设置,而 _function.scss 则存放了一些工具函数,例如。
假如读者自己去阅读源码的话,笔者将之前没见过的内建方法做一下简单的说明。
更多可以在 http://sass-lang.com/document... 找到
_gird.scss 里面则封装了一些布局范式,大多都是 @mixin ,在 sass 文件写法则以 = 开头。
新建 src/vars/_jeet.sass,将配置复制过来,以备修改
$jeet: (gutter: 3, max-width: 1440px, layout-direction: LTR, parent-first: false, nth: child)
新建 src/vars/_query-size.sass 设置响应式断点,参考的 bootstrap。box 的代表是内部 container 大小
$media-size-1: 576px !default$media-size-2: 768px !default$media-size-3: 992px !default$media-size-4: 1200px !default$media-size-box-1: 540px !default$media-size-box-2: 720px !default$media-size-box-3: 960px !default$media-size-box-4: 1140px !default
新建 src/fns/_media-query.sass , 构建媒体查询区间 mixin
=media1 @media screen and (max-width: $media-size-2) @content=media2 @media screen and (max-width: $media-size-3) and (min-width: $media-size-2) @content=media3 @media screen and (max-width: $media-size-4) and (min-width: $media-size-3) @content=media4 @media screen and (min-width: $media-size-4) @content
新建 src/gird.sass,导入依赖,这个时候会报错,因为找不到 jeet。
@import ‘./vars/_jeet.sass‘@import ‘jeet/scss/_functions.scss‘@import ‘jeet/scss/index.scss‘@import ‘./vars/_query-size.sass‘@import ‘./fns/_media-query.sass‘
在项目跟目录下创建 .sassrc.js,这样就可以找到 node_modules 下面的 jeet 了,或者自己写长路径。
const { resolve } = require(‘path‘)const cwd = process.cwd()module.exports = { includePaths: [resolve(cwd, ‘node_modules‘), resolve(cwd, ‘src‘)]}
现在以非缓存模式启动
parcel index.html --no-cache