我尝试了HarpJS,一个NodeJS静态博客生成器。在教程中,元数据有这样的例子:
for article, slug in public.articles._data
a(href="/articles/#{ slug }")
h2= article.title
和_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"
}
}
如果我理解正确,for article
需要每个高级对象,我们可以获得带有article.title
的标题或带有article.date
日期的标题。但什么是slug
?它是 Jade/HarpJs 中的预定义变量吗?如果是这样,还有其他人,还是我弄错了概念?我找不到有关此主题的任何信息,如果有一篇好文章可以阅读,我将不胜感激。谢谢。
正如@Brennan在评论中建议的那样,第二个参数可能是索引。变量的简单替换和重命名article
和slug
证明了这一点。但还有一个问题。请考虑此示例:
{
"hello-world": {
"title": "Hello World.",
"date": "2013-02-28",
"test": {
"testContent": "123"
}
},
"hello-brazil": {
"title": "Hello Brazil.",
"date": "2013-03-04"
}
}
for s, a in public.articles._data
a(href="/articles/#{ a }")
h2= s.title
h3= s.date
h3= a
- var obj = s.test
h3= obj
h3= obj.testContent
此代码在编译过程中出错。如果我评论最后一行,它可以工作。而且我不能用文档中的片段替换最后一行:
each val, index in obj
h1=index + ': ' + val
没有嵌套和二维数组?
以下示例可能回答了这个问题:
<h1><%= title %></h1>
<ul>
<% for (var slug in public.posts._data) { %>
<% var post = public.posts._data[slug] %>
<li>
<a href="posts/<%= slug %>">
<%= post.title %>
</a>
</li>
<% } %>
</ul>
要回答原始问题,请参阅我的评论:
缺少文档。我不完全相信这会起作用。根据这个玉只支持每一个和同时构造。在其他语言中,for.中的第二个参数。循环中将是索引。这里可能是这种情况,但我找不到任何具体的文档
第二个问题是模拟对象的问题。
看起来您需要检查以确保您的属性在模拟数据中定义,或者执行一些检查以确保您期望的属性存在。