辅助函数帮助您在模板中快速插入内容,建议您把复杂的代码放在辅助函数而非模板中。
概要
hexo.extend.helper.register(name, function(){ });
|
范例
hexo.extend.helper.register('js', function(path){ return '<script src="' + path + '"></script>'; });
|
常见问题
定制 helper 应该放在哪里?
放置在 scripts/
或 themes/<yourtheme>/scripts/
目录中。
如何在我的定制 helper 中使用另外一个已经注册的 helper?
所有的辅助函数都在同一个上下文中执行。例如,在一个自定义的辅助函数中使用 url_for()
:
hexo.extend.helper.register('lorem', function(path) { return '<script src="' + this.url_for(path) + '"></script>'; });
|
如何在其他插件中使用已经注册的 helper?
hexo.extend.helper.get
会返回一个指定名字的 helper,但是你还需要一个 bind(hexo)
,就像这样:
const url_for = hexo.extend.helper.get('url_for').bind(hexo);
|