Como fazer com que a Stylus funcione com Express and Connect no CoffeeScript
-
27-10-2019 - |
Pergunta
Meu app.coffee tem esta aparência:
connect = require 'connect'
express = require 'express'
jade = require 'jade'
stylus = require 'stylus'
app = express.createServer()
# CONFIGURATION
app.configure(() ->
app.set 'view engine', 'jade'
app.set 'views', "#{__dirname}/views"
app.use connect.bodyParser()
app.use connect.static(__dirname + '/public')
app.use express.cookieParser()
app.use express.session({secret : "shhhhhhhhhhhhhh!"})
app.use express.logger()
app.use express.methodOverride()
app.use app.router
app.use stylus.middleware({
force: true
src: "#{__dirname}/views"
dest: "#{__dirname}/public/css"
compress: true
})
)
# ROUTES
app.get '/', (req, res) ->
res.render 'index',
locals:
title: 'Title'
# SERVER
app.listen(1234)
console.log "Express server listening on port #{app.address().port}"
Atualização: não consigo escrever os arquivos CSS.
Solução
Encontrou a resposta, acrescentou:
compile = (str, path, fn) ->
stylus(str).set('filename', path).set('compress', true)
Outras dicas
Você pode, é claro, fornecer sua própria função de compilação, mas ela substitui desnecessariamente a função padrão.Em vez disso, adicione a opção de depuração à sua chamada de middleware e inspecione onde as coisas estão dando errado:
app.use stylus.middleware
debug: true
force: true
src: "#{__dirname}/../public"
dest: "#{__dirname}/../public"
Para mim, o problema era definir o caminho src / dest errado.Tem certeza de que seus arquivos .styl estão realmente localizados na pasta de visualizações?
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow