2

根据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 编译器抱怨数据格式无效等.

有人面临同样的问题吗?

4

1 回答 1

5

您应该直接引用数据(即不带前缀的字段data

所以你应该像这样改变你的代码:

{
  loader: 'pug-html-loader',
  options: {
    data: {
      title: 'Hello World'
    }
  }
}

然后从您的 PUG 模板中引用它更新

doctype html
html
  head
    title= title
于 2017-06-07T20:53:28.783 回答