Yo
是基于 Mobile First
的策略而设计,并使用 Sass
开发的 CSS Framework
,具备轻量,易用,可配置,强扩展等特性,同时也适应于PC端的高级浏览器。
在使用之前,请先确保你的机器有能够编译 Sass
的环境并开始去了解一些 Sass 相关的知识(当然,这非常简单)。
与其它框架不同的是,实际上我们并不计划对外提供打包好的 yo.min.css
来供使用,而是推荐直接在 Yo
的 usage
目录下进行开发。这样你将能体会到 Yo
的众多功能和方法为开发所带来的便利,并感受到它的魅力。
好了,请仔细看下面的步骤,这可以帮你快速搞定一切:
请确保你已经安装过下述环境:
- Bower
- Node.js
- npm
- 安装:
bower install yo
- 安装gulp:
npm install gulp -g --registry=https://registry.npm.taobao.org
- 安装依赖:
npm install --registry=https://registry.npm.taobao.org
- 在Yo根目录下运行:
gulp watch
: 如果你想监听所有文件的变更gulp build
: 如果你只是想build一次该项目
通过上述的 环境搭建
,Yo
就已经可以在你的机器上跑起来了,在 Yo
根目录下运行 gulp test
,会在 usage/test
目录生成一个 test.css
,这表示一切OK(当然,项目中你可以将test文件夹移除)。
真正的编码之前,先看一下 Yo
的目录结构是非常重要的,这有助于理解并更好的使用它:
lib
目录是Yo
框架的底层代码,不要改动它,避免日后升级时遇到麻烦;usage
目录正是你的舞台,在这做业务的样式编码;usage/core
目录下的都是配置文件,比如你想改变某些设定的初始值;- 需要编译使用的文件(一般来说都是page级别的文件),放在
usage/page
目录下,编译后,会输出到usage/export
目录; usage
下的其它目录和lib
里的目录一一对应,用于放置扩展文件;
我们可以开始真正的使用 Yo
来进行编码了,下面将会展示一段最简单的代码,我们要做一个列表页,其对应的样式表文件为:list.scss
:
@charset "utf-8";
@import "../core/reset";
@import "../fragment/yo-flex";
@import "../fragment/yo-header";
@import "../element/yo-list";
// 下面这段模块化的代码,请新建一个 `m-xxx` 的文件并将代码移过去,然后 `@import` 到这里
// 为了方便演示,所以下述代码直接写在了这里
.m-xxx {
// 由于这里所需要的`list`和默认展示不同,所以使用 `yo-list` 进行扩展
@include yo-list(
$margin: .1rem,
$border-width: 1px,
$border-color: #ccc,
$radius: .1rem
);
}
首先,我们将 reset
引入 list.scss
,这是必须的;该列表页由一个 yo-header
和 yo-list
组成,于是引入与之相关的2个元件;同时,我们想要使用 flex
布局,所以引入了 yo-flex
元件。
在页面上请使用 list.scss
编译后的 list.css
文件。
Yo
做了一些全局的定义,这些定义也让设计变得意思。
为了能够让你的样式得到完整的解析,我们推荐你使用 HTML5 doctype
:
<!DOCTYPE html>
Yo
采用 Mobile First
的策略设计,首先要保证移动设备上的体验,至于不同的终端,可以配合 响应式
来做适配:
<meta name="viewport" content="initial-scale=1, minimum-scale=1, maximum-scale=1, user-scalable=no" />
如果应用需要考虑手动缩放的情况,可以将 maximum-scale=1, user-scalable=no
移除;但不建议移除 minimum-scale=1
,因为页面可能会被缩小到难以阅读的程度。
Yo
约束了2种项目所使用的长度单位
- 所有涉及到
border
的长度单位都是用px
; - 除
border
外,所有的长度设置都是用rem
单位;
为了让计算变得简单,我们改变了所有元素的盒模型,将其重置为 border-box
。当然,也包括常用的伪元素 ::before
和 ::after
。
*,
::before,
::after {
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box;
}
如果你长时间工作在 PC
平台上,这个设定可能需要一个适应的过程,但可以肯定的是,你一定会喜欢上它。
- iOS6.0+
- Android4.0+
- Latest Stable: Chrome, Safari, Opera, IE10+
Yo
的版本方针遵循 SemVer 规范,版本号采用 主版本号.次版本号.修订号
的格式。版本发布周期是透明的,并尽可能保证向前向后兼容,您可以根据我们的语义化版本方针进行版本控制。
master
分支为开发版本,稳定版本都发布在 releases tag 中。
最新稳定版: v2.1.2
开发中版本: v2.1.3
如想查看更多版本变更历史,请查看 ChangeLog
如果您的项目正在使用Yo
,过程中发现了任何问题,或者有任何帮助Yo
更完善的想法和建议,请直接给我提Issues和Pull Requests。
杜瑶,我目前居住在北京,就职于 Qunar,您可以在 Github 或者 Weibo 看到我的最近动态。当然,也可以通过我的个人站点,博客:CSS探索之旅,CSS参考手册 和 Web前端实验室 等信息了解更多。
源码和文档版权属于 doyoe.com。源码发布基于 the MIT license 开源协议。文档发布基于 Creative Commons 开源协议。