【发布时间】:2012-07-15 15:17:39
【问题描述】:
如何转换这一行
<body data-spy="abcd">
到 HAML 语法?
这个返回一个错误
%body{:data-spy => "abcd"}
【问题讨论】:
-
由于连字符而引发错误。只需将连字符的字符串用引号括起来:
%body{:'data-spy' => "abcd"}
如何转换这一行
<body data-spy="abcd">
到 HAML 语法?
这个返回一个错误
%body{:data-spy => "abcd"}
【问题讨论】:
%body{:'data-spy' => "abcd"}
HTML5 数据字段的 HAML 语法:
%div{ :data => {:id => '555'} }
现在,我开始搞砸了,看起来这只适用于“数据”——其他标签需要:
%div{ "star-datas" => "hello!" }
你的例子:
%body{:data => { :spy => 'abcd'}}
【讨论】:
:data => {'spy' => 'abcd'}
{ :'0' => 'this is a symbol', :'so-is-this' => true }
我不知道为什么我没有首先发布这个。在 HAML 中编写标签 <body data-spy="abcd"> 的“正确”方法是完全跳过 {} 并使用 ():
%body(data-spy="abcd")
如果您没有像 Ruby 一样评估属性的值,则根本不应该使用 {:key => value} 语法。对于静态 HTML 属性,请坚持使用 (key="value")。
原答案:
HAML 具有处理数据属性的特定语法,CrazyVipa's answer 总结得很好。
为了完整起见,我将指出,您也可以在此处和 Ruby 中您想在符号中使用连字符的任何其他地方使用带引号的符号语法:
%body{ :"data-spy" => "abcd" }
一般来说,:"text" 等同于"text".to_sym,允许您的符号包含通常由于解析器限制而不能包含的字符。以下均为有效符号:
:"symbol with spaces"
:"symbol-with-hyphens"
:"symbol
with
newlines"
:"def my_func(); puts 'ok'; end"
请注意,带引号的符号不适用于 Ruby 1.9 的新哈希语法:
{ :"key-1" => "value" } # works in 1.8/1.9
{ "key-1": "value" } # syntax error
【讨论】:
%div{ data: {id: '555'} }
%div{ data: { :"key-1" => "value" }}in Ruby 1.9+ new has syntax
:"key-1" => "value"
%div{data: {some_hyphenated_id: 'value'}}
并且 HAML 会自动将下划线转换为连字符,所以我得到:
<div data-some-hyphenated-id="value"></div>
仅供参考:如果您需要空属性,只需使用 true 而不是 'value'
哈姆:
%div{data: {topbar: true}}
%div{data: {image_carousel: true}}
HTML:
<div data-topbar></div>
<div data-image-carousel></div>
更具体地说,此语法对 ruby haml gem 以及将 language 设置为 ruby 的 grunt 任务 grunt-haml 有效(需要提到 ruby安装了haml gem)
【讨论】:
data-topbar 是我想要的。谢谢。