基于FIS的纯前端模块化解决方案efis-pure
- 不仅仅是脚本模块化,pure带给你模版、脚本、样式的组件化方案。
- 自动加载模块化依赖,无需手动引入静态资源。
- 与Node.js风格一致的模块化开发体验,告别
define
。
pure可以自动压缩、合并页面引用到的所有资源,配置灵活,一个命令完成性能优化,轻松实践雅虎14条优化规则。并且这一切优化无需任何后端框架或服务支持。
- 直接编写less文件,无需额外编译工具支持。
- 通过swig实现页面继承,后缀stpl会编译为html文件。
- 可以直接在脚本中通过
var template = __inline('path/to/template.tmpl');
引用经过了预编译的underscore模版,无需异步请求和解析。 - 也支持直接在脚本中通过
var render = __inline('path/to/template.atpl');
引用经过了预编译的art-template模版,无需异步请求和解析。 - 更多的前端语言支持可以参考辅助开发
- 通过
efis server start
就能开启本地调试服务器。 - 通过
efis release --watch --live
实现监听文件修改,自动刷新页面等功能。更多内容可以参考辅助开发。
-
安装 nodejs&npm
-
安装pure
npm install efis-pure -g efis -v
快速上手请参考前端模块化
如何使用模块化加载可以参考efis-pure-demo,大致需要以下几个步骤
- 在需要模块化资源管理的页面,如index.html中引用Mod,注意Mod需放在static文件夹内,因为这是模块化加载库,不能被模块化。 示例
- modules目录下添加页面脚本,如
main.js
,在页面中则可以通过require('main')
加载静态资源。 示例 - 需要引用其他模块,以jquery.js为例,只要在modules目录中添加代码,在main.js中就可以通过
var $ = require('jquery')
加载,在通过efis release
发布后,页面就会自动加载jquery.js与main.js。
efis-pure自带了一个目录规范
- 所有组件化的脚本、样式、图片均放在modules目录中,可以按照组件划分目录,非模块化的脚本放在lib目录中。
- pages目录下的页面文件会发布到项目根目录,静态资源会发布到static目录。
任何 目录规范
、部署规范
、编译规范
都是可配置的(配置代码)。
如果希望调整目录规范,建议将配置代码中roadmap.path的部分整体复制到项目的fis-conf.js中再进行调整,避免配置不符合预期的问题。
内置的规范包括:
modules
目录下的js、css、less文件都是模块化文件,脚本会自动包装define,无需手动添加。使用require.async或者require加载模块的时候id与文件的对应规则是这样的:
文件 | 引用id | 举个例子 |
/modules/main.js | main | var main = require('main'); |
/modules/jquery/jquery.js | jquery | var $ = require('jquery'); |
/modules/jquery/jquery.scroll.js | jquery/jquery.scroll | require('jquery/jquery.scroll'); |
/modules/ui/header/header.js | jquery | var $ = require('ui/header'); |
static
目录下的文件不被认为是模块化的,请直接在页面上使用script或link标签引用。
参考fis配置