分享一个基于 gulp 的前端模块化解决方案: gulpman,比 FIS 更简单、可控、灵活

2016-01-25 15:13:55 +08:00
 xunuoi
像百度 FIS 一样,按照模块化的方式来前端开发,更加清晰、简单、轻量级

基于 gulp ,简单、灵活,容易扩展和修改,懂点 gulp 的童鞋都可以自己修改、使用、组合。
不需要任何服务端的整合工作,这个与 FIS 有很大不同,不需要修改服务端代码来适配,就像正常的 html 一样,去引用你的 js 、 css 、 img 、 fonts 等资源,无侵入。

整合 SCSS ES6 Browserify|cssnano|uglify|imagmein|rev 等前端常用套件,同时有监视文件变动功能(watch),可配置的发布目录、资源目录、 CDN 等,方便开发,简单易用,一站式搞定。

安装就是 npm install gulpman --save-dev

安装完后,无需任何配置、整合,直接执行 gulp gm:init 就能立刻初始化项目,通过 gulp gm:publish 就可以立刻发布资源了。 gulp 的插件都可以随意组合进去,没有学习门槛。

详细使用可以看下: http://karat.cc/article/56a351c3e48d2d05682aa0ac

附上 github : https://github.com/xunuoi/gulpman


前端童鞋可以通过 gulpman 感受下前端模块化开发的便利、又不用折腾 FIS 这种涉及到前后端整合、各种配置语法的巨型框架~~
5546 次点击
所在节点    分享创造
15 条回复
xunuoi
2016-01-25 16:26:16 +08:00
因为国内网络情况,如果直接 npm 安装,可能 node-sass 或者 gulp-sass 会安装失败~
因此 gulpman 的脚本内置调用 cnpm 来安装 gulp-sass
shunia
2016-01-25 18:19:13 +08:00
兹词。
amrio
2016-01-25 18:46:52 +08:00
不知道有没有做到 F.I.S 的子依赖收集?
比如一个 js 依赖了一个 less , less 依赖了一张图片,图片修改后这些文件都一起重新构建,也就是 F.I.S 的递归编译过程
xunuoi
2016-01-25 19:19:27 +08:00
@amrio 并没有做子依赖收集,主要是跟 FIS 理念不一致, FIS 是用各种自己定义的注释、语法等,将 JS\CSS\其他资源做捆绑定位,已经脱离了 HTML 本身的规范。 gulpman 还是坚持 html 本身的原则,不将 css 等资源强行绑定到 js 中,如果修改了 scss 或者 less 或者图片,那么相应的输出资源会变动。这种前提下的开发,更可控、清晰、规范,不需要额外学习新的一套注释、编译规则等
xunuoi
2016-01-25 20:05:38 +08:00
@shunia 感谢兹词 :)
jeffjade
2016-01-26 00:01:49 +08:00
感谢分享;看着不错的样子; mark 下,之后抽空折腾看看。
xunuoi
2016-01-26 23:52:40 +08:00
@jeffjade 谢谢支持!
xunuoi
2016-01-26 23:53:34 +08:00
下午更新了 gulpman 版本,新添加嵌入图片 Base64 编码到 html/CSS 的特性,使用方式也是很简单:

图片的 src 后面添加 ?base64=true 即可:

<img src="./img/testb64.png?base64=true" />

CSS 类似, url()中的路径添加参数即可

这种方式会将 img 编码成 base64 直接嵌入到 html 或 css 中。一些下页面场景下会经常用到
xunuoi
2016-01-27 21:52:16 +08:00
gulpman 1.3.3 版本更新:

1 、新增对复杂目录和多级目录设定支持:

比如下面这种模板、静态文件复杂的、多级的路径:

gulpman.config({

'components': 'components/cc',

'runtime_views': 'runtime_views/rv',
'dist_views': 'dist_views/dv/dv',

'runtime_assets': 'runtime_assets/ra/ra',
'dist_assets': 'dist_assets/da'

})


2 、增加彩色 log

3 、增加 base64 关联的资源文件的自动关联编译,比如跟这个 base64 图片有关的 html 、 css 都会自动编译(监视模式下)
xunuoi
2016-01-28 19:48:29 +08:00
gulpman 已更新到 1.3.6

更详细使用参见: https://github.com/xunuoi/gulpman



如何用 gulpman 来支援 Reactjs 的开发?

首先安装 gulpman : npm install gulpman --save-dev

在 gulpman 中启用 React :

方法一: [推荐] 通过 script 标签引入 React 类库到 HTML(文件路径根据实际配置或有不同)

<script type="text/javascript" src="./lib/react-0.14.6/build/react.min.js"></script>
<script type="text/javascript" src="./lib/react-0.14.6/build/react-dom.min.js"></script>

方法二:直接在 ES6/JSX 文件中引入 React 模块:


import 'react'

然后就可以在 es6/jsx 文件中写你的 ReactJS 的代码了! 其他的配置、 babel 转换、 browseirfy 等都会由 gulpman 帮你自动完成!
ppwangs
2016-01-30 14:55:24 +08:00
楼主说的 FIS 是 FIS3 吗
123s
2016-01-31 18:57:29 +08:00
楼主,有群吗?想问点东西
xunuoi
2016-01-31 22:24:00 +08:00
@123s QQ 群: 62734799 , 加群请说明 gulpman

另外还可以直接去 github 上开 issue: https://github.com/xunuoi/gulpman
xunuoi
2016-02-04 15:33:17 +08:00
@123s Gulpman 1.4.2 更新

支持 html 中内联嵌入 CSS/Javascript

在资源 url 后面添加?_gm_inline 即可,比如:
<link rel="stylesheet" type="text/css" href="./dialog.css?_gm_inline">
xunuoi
2016-02-05 23:01:13 +08:00
1.4.7 更新

* 新增对 cdn_prefix 的数组和函数的传参支持。
如果传入数组,将按照随机来分配 cdn_prefix 给资源 url

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/253214

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX