开发者

Multi-line attribute values in HAML

I am using KnockoutJS which uses a json string within the data-bind attribute to indicate binding information. I also like using HAML.

This string can quickly become quite long, for example:-

%ul#task-list.unstyled{"data-bind" => "template: { name : 'taskHierarchy', foreach : contexts.children(), afterAdd: function(elem) { $(elem).hide().slideDown()开发者_JAVA百科 } }"}

A solution is to use the :plain filter as follows (slightly different from above):-

:plain
  <div data-bind = "template: {
    name: 'twoLineResourceTemplate',
    foreach: resources,
    afterAdd: function(elem) { $(elem).hide().slideDown() }
  }">
  </div>

Is there a neater way to do this using HAML constructs instead of the filter?

I have tried using the pipe character but it does not seem to work for HAML attributes.

Thanks!


I tried the pipe notation and it works for me:

%ul#task-list.unstyled{"data-bind" => |
"template: { "                      + |
"name : 'taskHierarchy',"           + |
"foreach : contexts.children(),"    + |
"afterAdd: function(elem) {"        + |
"$(elem).hide().slideDown()"        + |
"} }"}                                |


You could try this post on KnockoutJS and Unobtrusive JavaScript

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜