codecamp

Harp 元数据

概述

元数据是具有作用域的数据,从 _data.json 文件传到指定的页面中。

有时你可能希望将变量分离开来,或者说将所有的全局数据放在一个文件中并非有利。文件元数据来做这件事情是完美的。

_data.json 文件比较特别,让数据在模板中可用。

示例

myproject/
  ├ harp.json               <-- Global metadata goes here
  ├ index.jade
  └ articles/
      ├ _data.json           <-- Article metadata goes here
      ├ hello-world.jade     <-- hello world article
      └ hello-brazil.jade    <-- hello brazil article

你的应用可以有多个 _data.json 文件,每一个放在他们自己的文件夹中。你也可以在根目录中包含一个 _data.json 文件来为你根目录中的页面设置元数据。

你的 _data.json 文件可能包含下面的内容:

{
  "hello-world": {  <-- available everywhere as public.articles._data
    "title": "Hello World.",
    "date": "2013-02-28"
  },
  "hello-brazil": {
    "title": "Hello Brazil.",
    "date": "2013-03-04"
  }
}

因为 hello-world 匹配文件名,在服务启动时,这些变量会在 hello-world.jade 模板文件中可用。这个对象也可以作为 public.articles._data.hello-world 在所有的模板文件中使用。

_harp.json 或者 harp.json 文件中的任何元数据都会被 _data.json 文件中的本地元数据所覆盖。这个特性允许你,例如,为整站指定一个标题,然后在具体的页面上覆盖它。(这里有 一个样例)。

没有必要在 _data.json 中包含文件扩展名。例如,"hello-world.jade":{...},将会抛出一个错误。

在 index 模板中,我们可能会遍历所有的文章来创建一个文章列表。

for article, slug in public.articles._data
  a(href="/articles/#{ slug }")
    h2= article.title

参考


Harp 全局变量
Harp 内容
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }