- Stylus 概述
- 选择器(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
文章来源于网络收集而来,版权归原创者所有,如有侵权请及时联系!
导入(@import)
导入
Stylus支持字面@import CSS, 也支持其他Stylus样式的动态导入。
字面CSS
任何.css
扩展的文件名将作为字面量。例如:
@import "reset.css"
渲染如下:
@import "reset.css"
Stylus导入
当使用@import没有.css
扩展,会被认为是Stylus片段(如:@import "mixins/border-radius"
)。
@import工作原理为:遍历目录队列,并检查任意目录中是否有该文件(类似node的require.paths
)。该队列默认为单一路径,从filename
选项的dirname
衍生而来。因此,如果你的文件名是/tmp/testing/stylus/main.styl
,导入将显现为/tmp/testing/stylus/
。
@import也支持索引形式。这意味着当你@import blueprint
, 则会理解成blueprint.styl
或blueprint/index.styl
. 对于库而言,这很有用,既可以展示所有特征与功能,同时又能导入特征子集。
如下很常见的库结构:
./tablet
|-- index.styl
|-- vendor.styl
|-- buttons.styl
|-- images.styl
下面这个例子中,我们设置paths
选项用来为Stylus提供额外路径。在./test.styl
中,我们可以@import "mixins/border-radius"
或@import "border-radius"
(因为./mixins
暴露给了Stylus)。
/** * 依赖模块 */ var stylus = require('../') , str = require('fs').readFileSync(__dirname + '/test.styl', 'utf8'); var paths = [ __dirname , __dirname + '/mixins' ]; stylus(str) .set('filename', __dirname + '/test.styl') .set('paths', paths) .render(function(err, css){ if (err) throw err; console.log(css); });
JavaScript导入API
当使用.import(path)
方法,这些导入是被推迟的,直到赋值。
var stylus = require('../') , str = require('fs').readFileSync(__dirname + '/test.styl', 'utf8'); stylus(str) .set('filename', __dirname + '/test.styl') .import('mixins/vendor') .render(function(err, css){ if (err) throw err; console.log(css); });
下面语句:
@import 'mixins/vendor'
等同于:
.import('mixins/vendor')
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论