stylus中文版参考文档之连接中间件(Connect Middleware)
回到相关文章 »文档:
- 选择器(Selectors)
- 变量(Variables)
- 插值(Interpolation)
- 运算符(Operators)
- 混合书写(Mixins)
- 方法(Functions)
- 关键字参数(Keyword Arguments)
- 内置方法(Built-in Functions)
- 其余参数(Rest Params)
- 注释(Comments)
- 条件(Conditionals)
- 迭代(Iteration)
- @import
- @media
- @font-face
- @keyframes
- @extend
- url()
- CSS字面量(CSS Literal)
- CSS样式解析(CSS Style Syntax)
- 字符转码(Char Escaping)
- 可执行性(Executable)
- 错误报告(Error Reporting)
- 连接中间件(Connect Middleware)
- 自检API(Introspection API)
- JavaScript API
- Nib下CSS扩展(CSS3 Extensions with Nib)
- Stylus在线体验!
详细:
连接中间件(Connect Middleware)
连接中间件
有了连接中间件,无论Stylus片段什么时候改变,这些片段都能够自动编译。
stylus.middleware(options)
选项
返回给定options
下的连接中间件。
`serve` Serve the stylus files from `dest` [true] `force` Always re-compile `src` Source directory used to find .styl files `dest` Destination directory used to output .css files when undefined defaults to `src`. `compile` Custom compile function, accepting the arguments `(str, path)`. `compress` Whether the output .css files should be compressed `firebug` Emits debug infos in the generated css that can be used by the FireStylus Firebug plugin `linenos` Emits comments in the generated css indicating the corresponding stylus line
上面中文翻译如下:
`serve` 从 `dest` 提供stylus文件 [true] `force` 总是重新编译 `src` 资源目录用来查找 .styl 文件 `dest` `src`默认为undefined时,用来输出 .css 文件的目标目录 `compile` 自定义编译函数,接受参数`(str, path)`. `compress` 是否输出的 .css 文件要被压缩 `firebug` 生成的CSS中发出调试信息,可被Firebug插件FireStylus使 用 `linenos` 生成的CSS中发出注解,表明响应的stylus行
例子
从./public
提供.styl
文件。
var app = connect(); app.middleware(__dirname + '/public');
改变src
以及dest
项来修改.styl
文件哪里被加载,哪里被保存。
var app = connect(); app.middleware({ src: __dirname + '/stylesheets', dest: __dirname + '/public' });
这里我们建立自定义的编译函数,这样,我们就能设置compress
项,或是定义附加的函数。
默认情况下,编译函数是简单地设置filename
以及渲染CSS. 在下面这个例子中,我们压缩输出内容,使用"nib"库插件,以及自动导入。
function compile(str, path) { return stylus(str) .set('filename', path) .set('compress', true) .use(nib()) .import('nib'); }
作为选项传递应该像这样:
var app = connect(); app.middleware({ src: __dirname , dest: __dirname + '/public' , compile: compile })