我一直在玩使用jetbrains webstorm IDE的节点。昨晚我试图设置nib和bootstrap-stylus。但是我总是得到一个错误,即在导入标签中找不到笔尖或引导程序。
@import 'nib'
或
@import 'bootstrap'
然而,如果我使用
@import '../../node_modules/bootstrap-stylus/lib/bootstrap'
一切都按预期工作。我认为这不是正确的方法吗?必须有一些方法告诉手写笔在哪里寻找进口?
我的app.js看起来像这样
/**
* Module dependencies.
*/
var express = require('express');
var routes = require('./routes');
var user = require('./routes/user');
var http = require('http');
var path = require('path');
var nib = require('nib');
var bootstrap = require('bootstrap-stylus');
var app = express();
// all environments
app.set('port', process.env.PORT || 3000);
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.json());
app.use(express.urlencoded());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));
function compile(str, path) {
return stylus(str)
.set('filename', path)
.set('compress', true)
.use(nib());
}
app.use(stylus.middleware({
src: path.join(__dirname, 'public')
, compile: compile
}));
// development only
if ('development' == app.get('env')) {
app.use(express.errorHandler());
}
app.get('/',routes.index); app.get('/ users',user.list);
http.createServer(app).listen(app.get('port'),function(){ console.log('快速服务器侦听端口'+ app.get('port')); });
谢谢!
答案 0 :(得分:1)
它应该像重写compile()
函数一样简单:
function compile(str, path) {
return stylus(str)
.set('filename', path)
.set('compress', true)
.use(nib())
.use(bootstrap()); // each plugin has to be loaded
}
有关插件使用和手写笔的更多信息,请访问:https://gist.github.com/jenius/8263065 在官方文档中:http://learnboost.github.io/stylus/docs/js.html#usefn