codecamp

Harp 当前对象

当前对象是在你的应用导航中应用激活状态的最好方式。它对每个模板可用,并且包含当前被渲染页面的状态。

当复用像导航这样的模板时,当前对象对于给导航应用一个激活状态是非常有用的,还有可能以非传统的方式渲染布局或者局部视图。这让我们的应用代码保持“尽量不要重复自己(DRY)”,而又不会让应用的可用性打折扣。

属性

  • path - (Array) 这是正在呈现的当前页面的文件路径。
  • source - (String) 它是路径数组中最后一个元素的快捷方式。

注意- 当前对象中的文件扩展名被忽略。

Harp 提供了一个当前页面路径的数组,通过一个叫做 current source 的列表中的最后一个元素。这个信息通过当前对象是可用的,在你访问的每个页面上都是动态更新的。

例如,访问 /articles/hello-world 时,下面的信息是可用的:

{
  path: ["articles", "hello-world"],
  source: "hello-world"
}

然而访问 /articles/ 时,当前对象是下面这样的:

{
  path: ["articles", "index"],
  source: "index"
}

现在,你可以在模板文件中使用这个了。

示例用法

这个应用有一个 index.jade 和 about.jade 页面。这些页面都有一个简单的导航,包含在 _nav.jade 局部视图 中。

通过在 _nav.jade 模板中使用当前对象,你可以告诉 nav 模板正在被渲染的上下文(即,当前访问的是哪一个页面)。

给定下面一个项目:

myproject/
  |- index.jade
  |- about.jade
  +- _nav.jade

Jade 示例

_nav.jade 文件,使用 current.source :

ul
  li(class="#{ current.source == 'index' ? 'active' : '' }")
    a(href="/") Home
  li(class="#{ current.source == 'about' ? 'active' : '' }")
    a(href="/about") About

EJS 示例

同样的模板,_nav.ejs 而不是 nav.jade

<ul>
  <li class="<%- current.source == 'index' ? 'active' : '' %>">
    <a href="/">Home</a>
  </li>
  <li class="<%- current.source == 'about' ? 'active' : '' %>">
    <a href="/about">About</a>
  </li>
</ul>

有了 current.source , 你现在可以在导航上拥有依赖上下文的 classes。这些然后可以通过 CSS 样式化,或者你的预处理器选择:Sass, LESS,或者 Stylus

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; }