0

私は、jetbrains webstorm IDE を使用してノードをいじっています。昨夜、ペン先とブートストラップスタイラスをセットアップしようとしていました。ただし、インポートタグにnibまたはbootstrapが見つからないというエラーが常に発生します。

@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('Express server listen on port ' + app.get('port')); });

ありがとう!

4

1 に答える 1

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

于 2014-10-22T10:30:02.683 に答える