根据pug-html-loader的自述文件,加载程序接受一个对象,该对象作为模板data
的一部分传递。虽然在pug API 参考options
中不可用,但我发现的一个 grunt 插件(grunt-contrib-pug)以相同的方式使用 API。options
我为加载程序指定了以下选项:
loader: 'pug-html-loader',
options: {
pretty: true,
exports: false,
debug: !env.production,
compileDebug: !env.production,
cache: config.build.useCaching,
doctype: 'html',
data: {
title: config.metadata.title,
baseUrl: config.build.baseUrl,
server: env.server,
metadata: config.metadata
}
}
根据这个问题,我想通过以下方式访问:
title= data.title
但是,我在编译时总是遇到以下错误:
ERROR in Error: Child compilation failed:
Module build failed: TypeError: Cannot read property 'title' of undefined
出于调试目的,我在模板中包含了以下行:
-
console.log(' DATA! ' + data);
结果是:
DATA! undefined
我还通过声明一些乱码而不是对象(例如字符串、纯 json、数字..)来确保数据正确传递给 pug,然后 pug 编译器抱怨数据格式无效等.
有人面临同样的问题吗?