- 版本 1.0
- 面向对象:前端开发者
- 内容说明:描述如何使用steel框架
- 修改时间:2015.10.30
steel是一个致力于分离前后端职责的前端框架,它的思想是通过在浏览器与服务器之间共享网页渲染逻辑和一部分业务逻辑来实现跨浏览器、服务器的工作。
后端输出静态页,形如:
html
head
meta(charset='utf-8')
title Hello World
body
script(src="http://127.0.0.1/SteelHelloWorld/src/js/lib/lib.js")
script(src="http://127.0.0.1/SteelHelloWorld/src/js/app.js")
script.
steel.boot('app');
对应后端EPF框架所使用的phtml文件,输出如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0" />
<title>粉丝服务平台</title>
<link rel="stylesheet" href="http://127.0.0.1/css/mobile_base.css?version=<?= htmlentities($g_version_css, ENT_QUOTES, 'UTF-8') ?>" />
<script src="http://127.0.0.1/js/lib/lib.js?version=<?= htmlentities($g_version_css, ENT_QUOTES, 'UTF-8') ?>"></script>
<script src="http://127.0.0.1/js/app/groupmsg.js?version=<?= htmlentities($g_version_css, ENT_QUOTES, 'UTF-8') ?>"></script>
<?php include(dirname(__FILE__) . '/../../common/include/config.phtml') ?>
<script>steel.boot('app/groupmsg');</script>
</head>
<body></body>
</html>
| build /*上线目录,用于推静态池,gulp build命令生成*/
| doc /*文档目录,用来存放数据约定/接口文档等*/
| node_modules /*依赖的插件目录*/
| server_front /*debug目录,有gulp server 命令可生成*/
| server_back /*手动书写,用来模拟后端接口和路由文件*/
| src /*源码目录*/
| _html /*demo目录,存放纯静态的html文件,*/
| _psd /*用来存放psd文件,下划线目录文件不会带进仿真环境和上线环境*/
| css /*样式源码*/
| img /*图片目录*/
| js /*逻辑源码*/
| app /*用来存放应用配置文件*/
| common /*用来存放公用模块或组件*/
| comp /*用来存放各个模块(组件)*/
| example /*模块目录,例如名字叫example*/
controller.js /*模块控制器*/
logic.js /*模块逻辑*/
tpl /*模块模板*/
| children /*example的子模块目录,例如叫做children*/
controller.js /*子模块控制器*/
logic.js /*子模块逻辑*/
tpl /*子模块模板*/
| lib.js /*框架类库文件,gulp会合并该目录为一个文件叫lib.js*/
steel.js /*框架文件*/
jquery.js /*类库文件,或使用STK、kissy等其他任何库*/
debugConfig.js /*debug状态配置*/
| Gulpfile.js /*grunt配置文件*/
| package.json /*nodejs模块声明文件,用于会编辑模块依赖部分*/
steel使用require、module.exports、exports的方式处理加载依赖,使用方法同nodejs的require、module.exports、exports一致。
在文件app.js里对文件进行配置,例如:
/*app.js 内容 START*/
steel.config({
singlePage: fasle, //是否单页面,决定了a链接等的跳转与否,默认是true
basePath: '/', //若jspath与csspath没有配置自己的路径,则使用此路径
jsPath: '/js/', //配置jsPath基础路径
cssPath: '/css/', //配置css基础路径
ajaxPath: '/', //配置ajax基础路径
mainBox: document.body, //渲染所需的最外层id或节点
router: [ //配置路由信息
['/', 'controller/helloworld'],
['/index.html', 'controller/helloworld'],
['/html/index.html', 'null'],
['/html/', 'controller/helloworld'],
['/html/helloworld2.html', 'controller/helloworld2']
]
});
/*app.js 内容 END*/
- 前端模板文件统一由src/js/tpl目录管理
- 模板使用jade开发
- jade模板编写中文规范:http://segmentfault.com/a/1190000000357534 或 jade官网 http://jade-lang.com/
【最外层模块】:(最外层一般是指body)
body(s-tpl="tpl/helloworld", s-data="/helloworld")
约定:
- 节点由config中的mainBox属性获得。
- 可以配置的模块资源是s-tpl、 s-data、s-css、s-logic,不必配置s-controller属性。
- 在没有controller配置信息的情况下,渲染必须配置的条件是存在s-tpl与s-data,其中s-data为空时,其值标识为null,否则不能渲染。
- 必须配置路由信息,第二个参数可以为null,此时按节点所给的属性资源进行渲染。
【子模块】:
div(s-child, s-tpl="tpl/child", s-data="null", s-css="css/child", s-logic="logic/child", s-controller="controller/child" )
约定:
- 需要标识条件属性 s-child,没有标识s-child属性的将不被视为子模块。
- 可以配置的模块资源是s-child(必选)、s-tpl、s-css、s-logic、s-data、s-controller
- 在没有controller配置信息的情况下,渲染必须配置的条件是存在s-tpl与s-data,其中s-data为空时,其值标识为null,否则不能渲染。
【资源的配置方式】
control.set({
css: 'css/helloworld',
tpl: 'tpl/helloworld' 或 require('tpl/helloworld'),
data: '/helloworld' 或 {helloworld: 'hello'},
logic: 'logic/helloworld' 或 require('logic/helloworld')
});
或者
control.set('css', 'css/helloworld');
control.set('tpl', 'tpl/helloworld'); 或 control.set('tpl', require(''tpl/helloworld''));
control.set('data', '/helloworld'); 或 control.set('data', {type:'hellow'});
control.set('logic', require('logic/helloworld')); 或 control.set('logic', 'logic/helloworld');
【s-child与s-controller】
若s-child有值,则优先使用s-child的值作为controller配置与control.set('children', 'xx'),例如:
情况一:
div(s-child, s-controller="controller/helloworld2")
//此种情况下controller/helloworld2生效
情况二:
div(s-child="a", s-controller="controller/helloworld2")
--------------------------------------------------
control.set('children', {a: 'controller/helloworld1'});
//此种情况下controller/helloworld1生效
steel.router.set(url); //切换
steel.router.get() 获取当前页url数据资源获取
- logic的参数node:是指当前模块的box节点
- controller的两个参数:
control:{
set:function(type, res);//css, data, logic,
}
- rootScope//用于传递数据,可以把数据赋值给此变量,在父/子的controller里使用。
问:两个页面使用相同的模块,怎么破?
答:只需要写一份,同时include一个模块。
问:我在logic文件怎么调用controller方法?
答:不可以,两个文件各司其职,互不干扰。
- 模块的css需要有结束标识42px
例如: 当前模块controller.set({css: 'customMenu/main'}),那么在main.css这个文件的最底部需要写成: #S_CSS_customMenu_main{ 42px ; },这个id就是S_CSS_前缀加上所set的css把斜杠变成下划线后拼接而成的,用来表示css文件加载完成。
- 模板jade文件有两处可被使用
除了被control.set({tpl: 'tpl/customMenu/main'})用来渲染外,其他需要用到html模板的地方也可以通过require的办法使用。例如:
var tplFn = require('tpl/customMenu/main');
var html = tplFn(data);
//此方法可以取到所需要的动态模板。
gulp版本的工具是grunt构建工具的改进版,性能更高,提升了开发效率 该集成开发工具集成了多种处理任务,这些处理任务依赖的环境如下:
nodejs、gulp
Nodejs :参考http://nodejs.org/ v0.10+
gulp :npm install -g gulp
nodejs deps :npm install
- 默认端口80
- 可使用的命令:
- gulp debug*:调试处理:对src目录文件进行debug处理,生成调试代码,包括模板处理、脚本wrap和合并、静态文件copy等
- gulp dist*:仿真处理:对src目录文件进行dist处理,生成仿真代码,除做debug中的处理外,还有css压缩合并
- gulp build*:上线处理:生成上线文件,会把可上线的结果处理了build目录下
- gulp server*:启动调试服务器命令 --dist 为仿真服务器 --pm2 为使服务后台运行(win下无效)');
- gulp serverStop*:关闭服务器命令 当存在后台服务时有效
- server_back目录:用来模拟后端的文件放置目录(路由和接口)
- 分为aj和非aj两种目录。aj目录用来存放假接口与使用grunt (另一种工程构建方式)时的假接口目录作用一样;非aj目录用来模拟后端的路由及后端输出。
- server_front目录:debug目录,用来存放静态文件
- 工具自动生成,与使用grunt时的debug目录作用一样
- 生成来源:src目录
- host配置 ——
- gulpfile配置 ——
port:服务端口
pathnamePrefix:'/', //工程path
front_base:'server_front', //debug目录名
back_base:'server_back', //模拟后端的文件放置目录
front_hostname:'127.0.0.1', //静态资源host配置,与host
back_hostname : '127.0.0.1' //后端的host,目的是模拟后端的页面路由请求,提供前端可仿真的功能,比如 /index 对应 /html/index.html
- 上线前使用gulp build命令
- QB上线(wb)