Bulma 源码结构
源码基于 Bulma 0.4.0 版本。
一、入口文件 bulma.sass
bulma.sass
是 Bulma 使用 SASS 编译的入口文件。
sass bulma.sass css/bulma.css
bulma.sass
内容如下:
/*! bulma.io v0.4.0 | MIT License | github.com/jgthms/bulma */
@charset "utf-8"
@import "sass/utilities/_all"
@import "sass/base/_all"
@import "sass/elements/_all"
@import "sass/components/_all"
@import "sass/grid/_all"
@import "sass/layout/_all"
包含了 Bulma 框架的所有 6 个子部分的入口文件(_all.sass
)。分别是工具、基础、元素、组件、网格、布局。
学习的顺序是这样的:
- 工具
- 基础
- 布局
- 网格
- 元素
- 组件
二、六个部分
源码结构如下:
├─base 基础
│ **generic.sass**
│ **helpers.sass**
│ **minireset.sass**
│ _all.sass
│
├─components 组件
│ card.sass
│ level.sass
│ media.sass
│ menu.sass
│ message.sass
│ modal.sass
│ **nav.sass**
│ pagination.sass
│ panel.sass
│ tabs.sass
│ _all.sass
│
├─elements 元素
│ **box.sass**
│ button.sass
│ content.sass
│ form.sass
│ icon.sass
│ image.sass
│ notification.sass
│ other.sass
│ progress.sass
│ table.sass
│ tag.sass
│ title.sass
│ _all.sass
│
├─grid 网格系统
│ **columns.sass**
│ tiles.sass
│ _all.sass
│
├─layout 布局
│ footer.sass
│ **hero.sass**
│ section.sass
│ _all.sass
│
└─utilities 工具
controls.sass
**functions.sass**
**mixins.sass**
**variables.sass**
_all.sass
文件树中加粗的部分是以后重点叙述的。源码被分在了 6 个部分,放在 6 个子文件夹里。每个子文件里都有 _all.sass
——每个部分的入口文件。
2.1 utilities/_all
@charset "utf-8"
@import "functions.sass"
@import "variables.sass"
@import "mixins.sass"
@import "controls.sass"
一共有四个工具文件,分别是函数、变量和混合(Mixin)。controls.sass
中定义是控制类样式的混合(Mixin)。
functions.sass
仅有一个方法 findColorInvert($color)
,作用是基于颜色的亮度,返回 70% 透明黑色或 100% 不透明白色。仅在 variables.sass
中计算 Inverse 颜色使用。
variables.sass
中定义的变量,主要作用:
- 颜色变量
- 文字大小、粗细、字体变量
- 几种不同设备的宽度(769px、1000px、1192px 和 1384px,分别对应平板、桌面、宽屏、大屏)。
mixins.sass
中定义了混合,其中重要的应用就是媒体查询了。
// $desktop 在 variables.sass 中定义,如下:
// 960px container + 40px
// $desktop: 1000px !default
=desktop
@media screen and (min-width: $desktop)
@content
.container
position: relative
+desktop
margin: 0 auto
width: $desktop - 40px
被编译为
.container {
position: relative; }
@media screen and (min-width: 1000px) {
.container {
margin: 0 auto;
width: 960px; } }
这段代码的意思是,设置 .container
元素在桌面环境(desktop)下的宽度,并且居中显示。
注意到 @content
内容是去掉与 +desktop
同级样式后包含父级元素的所有样式代码:
.container {
margin: 0 auto;
width: 960px; }
这些样式代码替代 @content
然后包含在 @media screen and (min-width: $desktop)
中就是最后得到的代码了。而 =desktop
只是中间媒介。
controls.sass
中也是 Mixin,这里不说了。
2.2 base/_all
@charset "utf-8"
@import "minireset.sass"
@import "generic.sass"
@import "helpers.sass"
minireset.sass
是为了统一 HTML 标签在各浏览器渲染样式(通过 CSS 重置 )。主要有:
- 规范盒模型:
box-sizing: border-box
。 - 规范媒体元素行为:
height: auto
、max-width: 100%
。 - 合并表格边框:
border-collapse: collapse
、border-spacing: 0
。 - 几乎所有 Block 元素:
margin: 0
和padding: 0
。
generic.sass
与 minireset.sass
一点区别是:generic.sass
使用了 variables.sass
中定义的变量,但是 minireset.sass
中没有。
generic.sass
中的主要功能有:
- 设置字体。
- 设置页面背景色、
<code>
、<pre>
的背景色。 - 文字、链接(包含
:hover
状态下的)颜色。 <code>
、<pre>
的font-size
、padding
和<hr>
的margin
。
helpers.sass
提供了一系列辅助类,包括:
- 不同设备下的显示还是不显示。
- 文字居中、居右和居左。
- 左右中浮动
display
属性设置辅助类
2.3 elements/_all
元素
@charset "utf-8"
@import "box.sass"
@import "button.sass"
@import "content.sass"
@import "form.sass"
@import "icon.sass"
@import "image.sass"
@import "notification.sass"
@import "progress.sass"
@import "table.sass"
@import "tag.sass"
@import "title.sass"
@import "other.sass"
2.4 components/_all
组件
@charset "utf-8"
@import "card.sass"
@import "level.sass"
@import "media.sass"
@import "menu.sass"
@import "message.sass"
@import "modal.sass"
@import "nav.sass"
@import "pagination.sass"
@import "panel.sass"
@import "tabs.sass"
2.5 grid/_all
网格系统
@charset "utf-8"
@import "columns.sass"
@import "tiles.sass"
2.6 layout/_all
布局
@charset "utf-8"
@import "hero.sass"
@import "section.sass"
@import "footer.sass"
(完)
Bulma 源码结构的更多相关文章
- [译] 给PHP开发者的PHP源码-第一部分-源码结构
文章来自:http://www.hoohack.me/2016/02/04/phps-source-code-for-php-developers-ch 原文:http://blog.ircmaxel ...
- 轻量级富文本编辑器wangEditor源码结构介绍
1. 引言 wangEditor——一款轻量级html富文本编辑器(开源软件) 网站:http://www.wangeditor.com/ demo演示:http://www.wangeditor.c ...
- PostgreSQL9.2.4内核源码结构介绍
PostgreSQL的源代码可以随意获得,其开源协议也允许研究者任意修改,这里介绍一下PostgreSQL的源码结构以及部分实现机制.下载PostgreSQL源代码并减压后,其一级目录结构如下图: P ...
- Nginx源码结构
上一章对Nginx的架构有了一个初步的了解.这章,为了对源码仔细的剖析,先要对Nginx的源码结构有一个了解.从宏观上把握源码模块的结构. 一.nginx源码的3个目录结构 在安装的nginx的目录下 ...
- linux内核源码结构
一.概述 Linux内核庞大,但是这些文件的结构还是有章可循的,分别位于不同的目录下,各个目录功能相对独立. 二.源码结构表 目录名 描述 arch 体系结构相关的代码,对于每个架构的CPU,arch ...
- OVS 总体架构、源码结构及数据流程全面解析
在前文「从 Bridge 到 OVS」中,我们已经对 OVS 进行了一番探索.本文决定从 OVS 的整体架构到各个组件都进行一个详细的介绍. OVS 架构 OVS 是产品级的虚拟交换机,大量应用在生产 ...
- Spring Boot 2.0系列文章(五):Spring Boot 2.0 项目源码结构预览
关注我 转载请务必注明原创地址为:http://www.54tianzhisheng.cn/2018/04/15/springboot2_code/ 项目结构 结构分析: Spring-boot-pr ...
- 【Android 系统开发】Android框架 与 源码结构
一. Android 框架 Android框架层级 : Android 自下 而 上 分为 4层; -- Linux内核层; -- 各种库 和 Android运行环境层; -- 应用框架层; -- 应 ...
- Nginx源码结构及如何处理请求
一.源码结构 1:下载安装包后,解压,可以看到目录结构,其中src目录下放的是源码 2:src源码目录下,可以看到这几个目录 mail:mail目录中存放了实现Nginx服务器 ...
随机推荐
- /dev/root: No such file or directory
/*************************************************************************** * /dev/root: No such fi ...
- inux中,关于多路复用的使用,有三种不同的API,select、poll和epoll
inux中,关于多路复用的使用,有三种不同的API,select.poll和epoll https://www.cnblogs.com/yearsj/p/9647135.html 在上一篇博文中提到了 ...
- [Wc2009]shortest
传送门 终于把这题过了,了了我两年前写堵塞的交通一晚上无果的心结 因为是6要注意蛇皮走位啊!!这种-> S //Achen #include<bits/stdc++.h> #defi ...
- 洛谷 P3223 [HNOI2012]排队
题目描述 某中学有 n 名男同学,m 名女同学和两名老师要排队参加体检.他们排成一条直线,并且任意两名女同学不能相邻,两名老师也不能相邻,那么一共有多少种排法呢?(注意:任意两个人都是不同的) 输入输 ...
- oracle中merge的用法,以及各版本的区别 Create
Merge是一个非常有用的功能,类似于Mysql里的insert into on duplicate key. Oracle在9i引入了merge命令,通过这个merge你能够在一个SQL语句中对一个 ...
- BZOJ2716:[Violet 3]天使玩偶
浅谈离线分治算法:https://www.cnblogs.com/AKMer/p/10415556.html 题目传送门:https://lydsy.com/JudgeOnline/problem.p ...
- 聊聊WPF中的Dispatcher
DispatcherObject,Dispatcher,Thread之间的关系 我们都知道WPF中的控件类都是从System.Windows.Threading.DispatcherObject继承而 ...
- git学习4 常用命令
1:更新: 更新后,更新只在Workspace中,没有到暂存区.git status可以查看当前状态. git add <file> 可以放到待提交区. git checko ...
- 侯捷STL学习(七)--深度探索vector&&array
layout: post title: 侯捷STL学习(七) date: 2017-06-13 tag: 侯捷STL --- 第十六节 深度探索vector vector源码剖析 vector内存2倍 ...
- 发任务找不到test-unit报错
发任务的时候因找不到gem包test-unit报错, 出错行: require 'test/unit' require 'test/unit/testresult' 解决办法如下 1.通过命令查看ge ...