7 天 600 stars, Mobi.css 是如何诞生的

受邀写一篇 Mobi.css 的诞生历程,请原谅我吸引眼球的标题,我会努力把这篇文章写得有一些干货的。css

GitHub Repo | Homepagegit

提要:github

Mobi.css 是一个轻量、灵活的移动端 CSS 框架。发布一周以来,得到了 600+ stars,登上了 GitHub Trending Top1(CSS),在 Hacker News 上进入了前三。web

这篇文章会先介绍一下创造 Mobi.css 的思路,再介绍一下我在推广 Mobi.css 中的心得。微信

为何要创造 Mobi.css

当我在设计一个新的 Focus on 移动端用户的网站(好比面向微信用户的网站)的时候,调研了一些现有的 CSS 框架,应用比较普遍的有 Bootstrap, Foundation, Pure.css, Framework7, Skeleton 等。框架

他们都很优秀,可是都有一些缺点。工具

  • Bootstrap: 太大太笨重了,对于桌面端用户我但愿展现与手机端同样的页面,可能再加上一个二维码,将用户导向微信(相似于微信公众号的文章在网页中的样式)测试

  • Foundation: 没有实践过,看上去也很大,大部分都是我不须要的功能字体

  • Skeleton: 在移动端有一些 bug,overflow:auto; 的滑动不平滑,<select> 样式太丑,官网的 <pre><code> 在 iPhone 里根本不 work,说明他们没有在手机上测试过网站

  • Framework7: 适合作 WebApp,而我不太喜欢那种仿原生 App 的设计

  • Pure.css: 很优秀,足够小巧,没什么特别的缺点,若是定制一下应该也能够知足需求。不过我还但愿框架层面可以有一些针对移动端的设计

因而我决定本身造一个轮子。

造新轮子以前必定要作好调研,不然可能白费了功夫。

开发过程当中的心得

善用工具

CSS 框架相比于 JavaScript, React 等简单得多,可是也不能忽视了工具的使用。我选择了如下工具:

  • Sass (scss)/Autoprefixer: CSS 预处理器都大同小异,Sass 功能比较全,因此选择了它。移动端也须要兼容不一样设备,Autoprefixer 能够自动加上 -webkit- 等前缀

  • Ejs/Marked/Highlight.js: 构建 website 的工具,一开始是手写 HTML,发现根本 hold 不住。这些工具后期能够用静态网站生成器替换

  • Gulp: 构建工具,串起其余工具

  • Travis CI/GitHub Pages/Coding Pages: 静态页面服务,一开始手动部署网站,后来发现太麻烦了,就用 Travis 自动部署了

磨刀不误砍柴工,善用工具能够大大提升开发效率。

站在巨人的肩膀上

开源社区上的代码都是别人的积累,若是离开了它们,Mobi.css 很难在短期内完成开发,我借鉴了如下开源项目:

  • Normalize.css: 大部分 _reset.scss 部分是借鉴它的。没有直接引入它的缘由是有少部分它的代码是不须要的

  • Bootstrap v4: 使用最普遍的 CSS 框架,可借鉴的太多了

  • Pure.css/Skeleton: 借鉴了手机上的样式

  • 微信公众号的 desktop 版: 借鉴了在 desktop 上的样式,以及中文字体

  • 以及不少其余框架

重视写文档

开源项目要受欢迎,文档是很是重要的。README.md 要让你们能在短期内了解项目的特色。网站要可以尽量输出本身的理念。

若是能够的话,最好用英文(或者双语)写。不然只能有中国人来关注你的项目了。要知道,外国开发者比中国开发者多不少倍的。

不要担忧本身英语很差,只要表达的内容能让外国人看得懂便可。等项目成熟了,天然会有人帮你修改文档。

注意社区的一些规则

  • 标明 License

  • 遵照版本号规则,不要乱作 Breaking changes

如何推广

不要以为很差意思推广,咱们推广不是功利性的求赞求关注(逃。

而是由于没有人关注的项目,是不可能向好的方向发展的。而若是本身不作主动的推广,项目也很难被关注。

推广这部分其实我并非很擅长,这里只写出一些我本身的心得吧。

在对的时间发对的帖

通常在下班的时间,你们都会拿出手机刷一刷。这时你的贴最容易被曝光。等到人气上去了,晚上睡觉以前你们再刷一波手机,就有更多人看到了。

发帖的时候只须要简要的说重点,引导用户到 GitHub 或你的网站。可是慎用「求 star」等字眼,功利性太强。

推广渠道

我用了如下推广渠道(按推广效果排序):

  • Hacker News

  • V2EX

  • 开发者头条

  • SegmentFault

  • Hacpai

  • Startup News

  • 光谷社区

  • Reddit

聆听意见,及时反馈

本身的想法总归是一我的的,吸收了别人的建议才能让项目更好的发展。Mobi.css 就有一部分 API 是听取了别人的建议以后修改的。

固然,本身须要有本身的判断。Mobi.css 的准则很简单:这个设计是否是 focus on mobile 的。

最重要的是,项目要有价值

没有价值的项目即便推广再多,也没有人会关注的,只会招来一顿猛喷。

总结

Mobi.css 在短期内得到了不少关注,离不开你们的支持,离不开开源社区的帮助。

我知道这只是 Mobi.css 项目的开始,后面有更长的路要走,感兴趣的能够一块儿来建设。

GitHub Repo | Homepage

Hacker News 上的讨论

相关文章
相关标签/搜索