Модуль Express.js hbs - зарегистрировать частичные файлы из файла .hbs
Я использую handlebars.js hbs wrapper в express.js. У меня есть шаблоны, работающие нормально, но мне нужно добавить частичные части, которые будут отображаться с моими представлениями.
Я хотел бы сделать что-то вроде этого:
hbs.registerPartial('headPartial', 'header');
// where "header" is an .hbs file in my views folder
Тем не менее, это бросание "частичного заголовка не может быть найдено".
Я могу сделать registerPartial работу, если я передам строку html ко второму параметру, но я бы хотел использовать отдельные файлы просмотра для своих партиций.
Я не нашел никакой документации по этому поводу, но надеюсь, что мне просто не хватает чего-то легкого.
Кто-нибудь знает, как использовать файлы вида в методе registerPartial? Если да, как это реализовать?
UPDATE
Чтобы дать больше контекста, позвольте мне добавить еще код.
Вот мой "серверный" файл - app.js
var express = require('express')
, routes = require('./routes')
, hbs = require('hbs');
var app = module.exports = express.createServer();
// Configuration
app.configure(function(){
app.set('views', __dirname + '/views');
app.set('view engine', 'hbs');
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(__dirname + '/public'));
});
app.configure('development', function(){
app.use(express.errorHandler({ dumpExceptions: true, showStack: true }));
});
app.configure('production', function(){
app.use(express.errorHandler());
});
// this is the line that generates the error
hbs.registerPartial('headPartial', 'header');
// What I'm expecting is for "headPartial" to be a compiled template partial
// of the template within views/header.hbs, but it is not loading this way.
// If I do something like hbs.registerPartial('headPartial', '<p>test</p>');
// then it does work. I need to know how to pass an .hbs file to the
// registerPartial method.
// Routes
app.get('/', routes.index);
app.listen(3000);
И вот мой файл routes.index:
exports.index = function(req, res){
res.render('index', { title: 'Express' })
};
В моей папке views у меня есть три шаблона:
views/
header.hbs (this is my partial)
index.hbs
layout.hbs
В моем файле index.hbs я вызываю частицу "headPartial" с помощью:
{{> headPartial}}
Любая помощь очень ценится.
Ответы
Ответ 1
Этот код загружает все частичные шаблоны в каталог и делает их доступными по имени файла:
var hbs = require('hbs');
var fs = require('fs');
var partialsDir = __dirname + '/../views/partials';
var filenames = fs.readdirSync(partialsDir);
filenames.forEach(function (filename) {
var matches = /^([^.]+).hbs$/.exec(filename);
if (!matches) {
return;
}
var name = matches[1];
var template = fs.readFileSync(partialsDir + '/' + filename, 'utf8');
hbs.registerPartial(name, template);
});
Ответ 2
Для удобства registerPartials предоставляет быстрый способ загрузить все частичные файлы из определенного каталога:
var hbs = require('hbs');
hbs.registerPartials(__dirname + '/views/partials');
Частицы, загруженные из каталога, называются на основе их имени файла, где пробелы и дефисы заменяются символом подчеркивания:
template.html -> {{> template}}
template 2.html -> {{> template_2}}
login view.hbs -> {{> login_view}}
template-file.html -> {{> template_file}}
Ура!
Ответ 3
Похоже на создание переменной и вытягивание кода шаблона вручную:
var hbs = require('hbs')
, fs = require('fs')
, headerTemplate = fs.readFileSync(__dirname + '/views/_header.hbs', 'utf8');
и позже:
hbs.registerPartial('headPartial', headerTemplate);
Ответ 4
Для меня у меня был файл шаблона my-partial.hbs
Затем я попытался получить к ним доступ через:
{{> my-partial }}
Но часть была сохранена в hbs как my_partial независимо от имени файла.
Это благодаря hbs версии 3.1.0, строка 218
.slice(0, -(ext.length)).replace(/[ -]/g, '_').replace('\\', '/');
Это находится в readme
Ответ 5
Для меня у меня есть функция вроде:
var hbs = require('hbs');
var fs = require('fs');
var statupfunc = {
registerHbsPartials : function(){
//this is run when app start
hbs.registerPartials(__dirname + "/" + resource.src.views + '/partials');
},
registerOneHbsPartials : function(event){
//this is run for gulp watch
if(event.type == 'deleted')
{
return;
}
var filename = event.path;
var matches = /^.*\\(.+?)\.hbs$/.exec(filename);
if (!matches) {
return;
}
var name = matches[1];
var template = fs.readFileSync(filename, 'utf8');
hbs.registerPartial(name, template);
}
};
Запустите statupfunc.registerHbsPartials при запуске приложения, а затем зарегистрируйте gulp часы с statupfunc.registerOneHbsPartials, чтобы зарегистрировать частичные файлы при новом создании
gulp.task('watch', function() {
gulp.watch(resource.src.views + '/partials/*.*', statupfunc.registerOneHbsPartials);
});