`
yanzilee9292
  • 浏览: 540936 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

haml参考大全

阅读更多


Haml是一种用来描述任何XHTML web document的标记语言,它是干净,简单的。而且也不用内嵌代码。Haml的职能就是替代那些内嵌代码的page page templating systems,比如PHP,ERB(Rails的模板系统)ASP。不过, haml避免了直接coding XHTML到模板,因为它实际上是一个xhtml的抽象描述,内部使用一些code来生成动态内容。
 
它有什么特点呢?
1.    空格标识层次嵌套关系
2.       良好的标签格式
3.       DRYDon’t repeat yourself
4.       遵循CSS标准
5.       集成了Ruby代码
6.       .haml扩展名代替了rails模板(.rhtml
 
Haml的使用
Haml的使用有两种方式:
作为Ruby on Rails的插件来使用。
作为一个独立的Ruby module来使用。
 
Rails 插件方式:
这是使用Haml最常用的方式。当然,安装Haml的方式,就是Rails里常用的插件安装方式了:
一旦安装好以后,你必须以.haml为扩展名来使用。
你在ERB模板里可以使用的实例变量在Haml里照样可以使用,Helper方法也不例外。比如:
# file: app/controllers/movies_controller.rb
 class MoviesController < ApplicationController
    def index
      @title = "Teen Wolf"
    end
  end
# file: app/views/movies/index.haml
  #content
   .title
     %h1= @title
     = link_to 'Home', home_url
 
上面的haml代码会被编译为:
<div id='content'>
   <div class='title'>
      <h1>Teen Wolf</h1>
      <a href='/'>Home</a>
    </div>
  </div>
 
Ruby Module方式:
Haml可以完全从railsActionView里拿出来单独使用。下下面这样做:
  gem  install  haml
 
然后用Haml::Engine
engine = Haml::Engine.new("%p Haml code!")
engine.render #=> "<p>Haml code!</p>\n"
 
XTML Tags
下面这些字符会渲染出相应的xhtml tag
 
%
百分号符号是一行的开始,紧接着一个元素的名字,然后后面跟一个可选的修饰语(见下例),比如一个空格,或一行文本等,就会被渲染到这个元素里成为其内容。它会创建一个这样的形式:<element></element>.。举个例子:
  %one
    %two
      %three Hey there
会被编译为:
  <one>
    <two>
      <three>Hey there</three>
    </two>
  </one>
对于任何一个有效的标准元素字符,Haml都会自动的为其生成闭合标签。
 
{}
括号内的Ruby hash是用来指名一个元素的属性。它作为一个ruby hash的字面量,局部变量也可以在其中使用。Hash放在被定义好的标签之后,基本上就和Ruby语法一样,看例子:
 
  %head{ :name => "doc_head" }
    %script{ 'type' => "text/" + "javascript",
             :src   => "javascripts/script_#{2 + 7}" }
编译后为:
  <head name="doc_head">
    <script src='javascripts/script_9' type='text/javascript'>
    </script>
  </head>
 
方括号跟在一个标签定义之后,包含一个Ruby 对象,被用来为这个标签设置classid属性。这个class的值被设置为这个对象的类名(两个单词用下划线形式表示,而不是驼峰表示方法)并且id的值被设置为对象的类名加上这个对象的id,也是下划线连接。因为一个对象的id通常是朦胧的实现细节,这是表现model的实例最有用的元素了(这句是不是翻译的太差?)。看例子:
# file: app/controllers/users_controller.rb
  def show
    @user = CrazyUser.find(15)
  end
 # file: app/views/users/show.haml
  %div[@user]
    %bar[290]/
    Hello!
转换为:
  <div class="crazy_user" id="crazy_user_15">
    <bar class="fixnum" id="fixnum_581" />
    Hello!
  </div>
这是基于RailsConf Europe 2006 大会上DHH提出的SimpleHelpful语法
 
/
这个斜线字符,放在一个tag定义之后,可以让这个标签自我关闭。例子:
  %br/
  %meta{'http-equiv' => 'Content-Type', :content => 'text/html'}/
转换为:
  <br />
  <meta http-equiv='Content-Type' content='text/html' />
有一些标签(meta, img, link, script, br, and hr tags等)当没有内容的时候会自动关闭。看例子:
  %br
  %meta{'http-equiv' => 'Content-Type', :content => 'text/html'}
转换为:
  <br />
  <meta http-equiv='Content-Type' content='text/html' />
 
. and #
这两个符号是从CSS里借鉴来的。他们被用来表示一个元素的classid属性。
看例子:
 
  %div#things
    %span#rice Chicken Fried
    %p.beans{ :food => 'true' } The magical fruit
    %h1.class.otherclass#id La La La
转换为:
 
  <div id='things'>
    <span id='rice'>Chicken Fried</span>
    <p class='beans' food='true'>The magical fruit</p>
    <h1 class='class otherclass' id='id'>La La La</h1>
  </div>
注意h1标签。两个点连用,第一个表示class属性,第二个则是用来链接那两个字符的空格。
 
  #content
    .articles
      .article.title
        Doogie Howser Comes Out
      .article.date
        2006-11-05
      .article.entry
        Neil Patrick Harris would like to dispel any rumors that he is straight
转换为:
  <div id="content">
    <div class="articles">
      <div class="article title">Doogie Howser Comes Out</div>
      <div class="article date">2006-11-05</div>
      <div class="article entry">
        Neil Patrick Harris would like to dispel any rumors that he is straight
      </div>
    </div>
  </div>
 
Implicit Div Elements(隐藏DIV
因为Div这个标签经常被用,所以你仅用.and#这两个符号来定义classid的时候,一个div元素就会被自动的使用。例如:
  #collection
    .item
      .description What a cool item!
和下面的这个相似:
  %div{:id => collection}
    %div{:class => 'item'}
      %div{:class => 'description'} What a cool item!
都会被转换为:
  <div id='collection'>
    <div class='item'>
      <div class='description'>What a cool item!</div>
    </div>
  </div>
等号符号用来插入
分享到:
评论

相关推荐

    haml-to-php:PHP的haml实现

    请参阅如果您将对haml-to-php.com的支持添加到框架中,我想参考您的工作。 我知道的相关工作 请参阅此处。 最引人注目。 可能也很有趣。 如果您知道更多值得注意的HAML PHP实现,请告诉我 链接 (可能已过时) 捐款 ...

    Go-Amber一个Go编程语言的优雅模板引擎灵感来自HAML和Jade

    完整的官方文档提供了详细的使用指南和API参考,帮助开发者更好地理解和应用Amber。 7. **应用场景** Go-Amber适合于构建Web应用,尤其是那些重视代码整洁度和效率的项目。它也适用于快速原型开发,因为其简洁的...

    ruby on rails 2.2.2 参考手册

    本参考手册是学习Rails 2.2.2的重要资源,特别适合初学者和有一定经验的开发者。它提供了详尽的API文档,帮助开发者深入理解Rails框架中的各个组件和方法。以下是一些关键的知识点: 1. **MVC架构**:Rails的核心...

    PyPI 官网下载 | PyHAML-0.1.5.tar.gz

    2. **文档**:可能包含README文件,提供了库的基本介绍和使用指南,还有可能有其他的文档如API参考或示例代码。 3. **测试**:可能有一个`tests`目录,包含了单元测试用例,用于验证库的功能是否正常工作。 4. **...

    chicagocamps.org:芝加哥营地

    这对于开发者来说是一个学习和参考的好资源,特别是对于那些对Haml或Web开发感兴趣的人来说。同时,对于用户而言,如果想要了解更多关于芝加哥营地活动的详细信息,这个网站无疑是一个宝贵的资源。

    Agile Web Development with Rails,Fourth Edition 第四版

    对于视图部分,erb和haml模板语言的比较和选择,以及辅助方法的使用,都是书中重要的内容。此外,还会有关于样式表管理和响应式设计的讨论,帮助开发者构建适应不同设备的Web应用。 最后,本书会涉及部署策略,如...

    rail api文档

    文档将深入解析模板语言(ERB或Haml)、局部变量、辅助方法和布局的使用。 5. **Rails路由**:Rails的路由系统负责将URL映射到控制器行动上。文档会介绍配置路由的基本语法、资源路由和命名路由。 6. **Active ...

    Agile Web Development with Rails

    此外,书中还会介绍如何利用ActiveRecord进行数据库操作,使用 erb 或者 Haml 进行模板渲染,以及如何集成JavaScript和CSS来增强用户体验。 敏捷开发是一种强调适应变化、迭代和客户反馈的软件开发方法论。在《敏捷...

    使用 rails进行敏捷开发(第三版)

    7. **视图与模板引擎**:介绍ERB、Haml、Slim等模板语言,以及如何在视图中渲染数据。 8. **测试驱动开发(TDD)**:教授如何编写RSpec或Test::Unit测试,确保代码质量并遵循敏捷开发原则。 9. **ActiveSupport库**...

    ciao-app-dashboard

    您可以使用工具在几分钟内构建此应用程序,选择 Bootstrap 或 Foundation 前端框架,以及许多其他选项,例如 Haml 或 Slim。 还有一篇关于的有用文章,比较了 CanCan 和 Pundit gem,并查看了简单的基于角色的授权...

    SMILEdelivered

    您可以使用工具在几分钟内构建此应用程序,选择 Bootstrap 或 Foundation 前端框架,以及许多其他选项,例如 Haml 或 Slim。 还有一篇关于的有用文章,比较了 CanCan 和 Pundit gem,并查看了简单的基于角色的授权...

    Beginning Rails 3

    - **模板系统**:熟悉Rails内置的ERB模板引擎及其他第三方模板引擎,如HAML、SLIM等,提高开发效率。 #### 四、高级主题 - **插件与Gem管理**:了解如何使用插件(Gem)来扩展Rails应用的功能,以及如何管理和部署...

    Rails.Recipes.Rails.3rd和源码

    4. **视图**:涵盖模板语言ERB和Haml的使用,以及如何利用辅助方法和布局来美化界面。 5. **模型**:讨论ActiveRecord的查询接口,关联关系,以及如何进行数据验证。 6. **测试**:讲解RSpec和Cucumber等测试工具的...

    Ruby+Rails+社交+教程

    9. **模板和布局**:使用ERB(嵌入式Ruby)或HAML编写视图,创建用户友好的界面。同时,理解如何设置全局布局以保持一致性。 10. **测试**:Rails强调TDD(测试驱动开发),所以学习Rspec或MiniTest进行单元测试和...

    Agile Web Development with Rails.3rd Edition.2009

    6. **视图和模板**:Rails使用ERB或Haml等模板语言来构建视图层,书中会教授如何创建动态页面,以及如何利用辅助方法和布局提高代码复用。 7. **控制器和动作**:控制器负责处理HTTP请求并调用模型和视图。书会解释...

    Rails的中文乱码问题

    在提供的“ruby-refm.chm”文件中,可能包含了Ruby语言和相关工具的参考手册,这将有助于理解Ruby的基础语法和Rails框架的使用,包括如何处理字符串和编码问题。查阅此手册,可以找到关于字符串操作、编码转换等相关...

    ruby on rails 学习资料汇总

    本资料汇集了关于Ruby on Rails的学习资源,尤其是《Rails Recipes》这本书,它包含了丰富的实践案例和解决方案,适合初学者和进阶者参考。 在Rails框架中,"源码"标签意味着我们将深入理解其内部工作机制,包括...

    Agile Web Development with Rails-Second Edition-Beta一书例子

    《Agile Web Development with Rails-Second Edition-Beta》是一本专为Rails开发者设计的书籍,旨在教授敏捷Web开发的...书中可能还涵盖了部署、性能优化、安全等方面的知识,是Rails初学者和进阶者的重要参考资料。

    rails-tutorial-源码.rar

    本教程源码主要涵盖了Rails开发的基础到进阶的知识点,对于学习和理解Rails框架的运作机制具有极高的参考价值。 1. **Rails框架基础** - MVC架构:Rails的核心在于MVC设计模式,它将应用程序分为模型、视图和控制...

Global site tag (gtag.js) - Google Analytics