Haml
此條目翻譯自其他語言維基百科,需要相關領域的編者協助校對翻譯。 |
此條目需要補充更多來源。 (2017年5月24日) |
Haml(HTML Abstraction Markup Language,HTML抽象標記式語言)是一種模板系統,它可以避免在Web文件中內嵌代碼,使HTML更簡易和乾淨。Haml為HTML中提供了一些動態內容的靈活性。類似其他Web語言(如PHP、ASP、JSP)和模板系統(如eRuby),Haml也嵌入一些在執行時執行的代碼並生成HTML代碼,從而提供一些動態內容。為執行Haml代碼,檔案需要採用.haml副檔名。這些檔案類似.erb或eRuby檔案,這有助於在開發網路應用程式時嵌入Ruby代碼。在解析代碼注釋時,Haml採用與Ruby 1.9或之後版本相同的規則。Haml只能理解相容ASCII的編碼(例如UTF-8),而不能理解不相容ASCII的UTF-16與UTF-32。[4][5]Haml可以在命令列介面中使用,也可以作為一個單獨的Ruby模組或在一個Ruby on Rails應用程式中使用,這使Haml可用於廣泛的應用程式。
編程範型 | 模板引擎 |
---|---|
設計者 | Nick Walsh |
實作者 | |
目前版本 |
|
實作語言 | Ruby |
作業系統 | 跨平台 |
授權條款 | |
副檔名 | .haml |
網站 | haml |
歷史
編輯Haml最早由Hampton Catlin於2006年釋出,它的成果領先於其他幾個人。他的動機是使HTML更簡單、清晰和易於使用。自2006年以來,它已隨新版本釋出而多次修訂。2012年4月,Haml的維護由Norman Clarke接手。[6]Natalie Weizenbaum致力於使Haml可以在Ruby應用程式中使用,而品牌與設計則由Nick Walsh完成。目前的維護團隊中還有Matt Wildig、Akira Matsuda和Tee Parham。[2]
版本歷史
編輯特性
編輯Haml的發展有四項原則。
使用者友好的標記
編輯標示語言如果遵循下列特徵,那麼它則使用者友好:
- 語言能輕鬆理解
- 使用便捷(其實現)
DRY
編輯標記式語言應堅持不重複自身(DRY)原則。它應該:
- 避免不必要的重複
- 專注於乾淨的代碼
精巧縮排
編輯有良好縮排的標記式語言可以改善外觀、使閱讀器易於讀取,並有助確定元素的開始與結束位置。
清晰結構
編輯有清晰結構的標記式語言有助於代碼維護和理解最終結果的邏輯。Haml在這方面是否提供了有差異的優勢,這點尚不清晰。
例子
編輯Haml標記在語法上類似CSS。例如,Haml同樣使用.
(點)表示CSS的類,使開發人員可以輕鬆使用這種標記。
Hello, World例子
編輯Haml的最簡單的Hello World實現像是這樣:
%p{:class => "sample", :id => "welcome"} Hello, World!
得到這樣的HTML代碼:
<p class="sample" id="welcome">Hello, World!</p>
為執行Haml代碼,必須已安裝,如使用下列命令 Haml
以gem安裝:[7]
gem install haml
Haml代碼若以Hello.haml
為檔名儲存,則可以這樣執行:
haml Hello.haml
Haml作為Ruby on Rails附加項
編輯要用Ruby使用Haml,Ruby的Gemfile
應該包含此行:
gem 'haml'
類似eRuby,Haml也可以訪問局部變數(在同一個檔案中以Ruby代碼聲明)。此例子使用一個Ruby控制器檔案為例。
- file: app/controllers/messages_controller.rb
class MessagesController < ApplicationController def index @message = "Hello, World!" end end
- file: app/views/messages/index.html.haml
#welcome %p= @message
將得到:
<div id="welcome">
<p>Hello, World!</p>
</div>
Haml作為Ruby模組
編輯
要獨立於Rails和ActionView(頁面存檔備份,存於網際網路檔案館)使用Haml,安裝haml
gem,在Gemfile
中包含它,然後簡單的在Ruby指令碼中匯入[Usage: require 'haml']
,或者以-rubygems
標誌呼叫Ruby直譯器。
welcome = Haml::Engine.new("%p Hello, World!")
welcome.render
輸出:
<p>Hello, World!</p>
Haml::Engine(頁面存檔備份,存於網際網路檔案館)是一個Haml類。
基本例子
編輯Haml使用空格縮排(兩個空格)來表示標籤的巢狀和辨識給定標籤的範圍。這取代打開、閉合的標籤對系統,從而符合DRY並使其看上去更清晰(容易閱讀)。下列例子展示了Haml與eRuby(嵌入式Ruby)的差異。
Haml | ERB |
---|---|
%div.category
%div.recipes
%h1= recipe.name
%h3= recipe.category
%div
%h4= recipe.description
|
<div class="category">
<div class="recipes">
<h1><%= recipe.name %></h1>
<h3><%= recipe.category %></h3>
</div>
<div>
<h4><%= recipe.description %></h4>
</div>
</div>
|
由上述代碼範例呈現的HTML代碼如下所示:
<div class="category">
<div class="recipes">
<h1>Cookie</h1>
<h3>Desserts</h3>
</div>
<div>
<h4>Made from dough and sugar. Usually circular in shape and has about 400 calories.</h4>
</div>
</div>
兩者的關鍵差異是:
- Haml不像eRuby那樣,每個元素都有開始與結束
- eRuby語法看上去很像、更像HTML,而Haml更像CSS。
- Haml使用縮排來巢狀標籤元素,而eRuby使用與HTML相同的表示法
- 在Haml屬性中,
class
、id
可以用.
和#
表示class
和id
關鍵字。Haml使用%
標示一個HTML元素,而eRuby中使用<>
。
嵌入Ruby代碼的例子
編輯注意:這是一個簡單的預覽範例,可能不能體現此語言的目前版本。
!!!
%html{ :xmlns => "http://www.w3.org/1999/xhtml", :lang => "en", "xml:lang" => "en"}
%head
%title BoBlog
%meta{"http-equiv" => "Content-Type", :content => "text/html; charset=utf-8"}
%link{"rel" => "stylesheet", "href" => "main.css", "type" => "text/css"}
%body
#header
%h1 BoBlog
%h2 Bob's Blog
#content
- @entries.each do |entry|
.entry
%h3.title= entry.title
%p.date= entry.posted.strftime("%A, %B %d, %Y")
%p.body= entry.body
#footer
%p
All content copyright © Bob
上述Haml產生這個XHTML:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html lang='en' xml:lang='en' xmlns='http://www.w3.org/1999/xhtml'>
<head>
<title>BoBlog</title>
<meta content='text/html; charset=utf-8' http-equiv='Content-Type' />
<link href="/stylesheets/main.css" media="screen" rel="Stylesheet" type="text/css" />
</head>
<body>
<div id='header'>
<h1>BoBlog</h1>
<h2>Bob's Blog</h2>
</div>
<div id='content'>
<div class='entry'>
<h3 class='title'>Halloween</h3>
<p class='date'>Tuesday, October 31, 2006</p>
<p class='body'>
Happy Halloween, glorious readers! I'm going to a party this evening... I'm very excited.
</p>
</div>
<div class='entry'>
<h3 class='title'>New Rails Templating Engine</h3>
<p class='date'>Friday, August 11, 2006</p>
<p class='body'>
There's a very cool new Templating Engine out for Ruby on Rails. It's called Haml.
</p>
</div>
</div>
<div id='footer'>
<p>
All content copyright © Bob
</p>
</div>
</body>
</html>
實現
編輯Haml的官方實現已經以Ruby外掛程式形式內建在Ruby on Rails和Merb中,該Ruby實現也能夠獨立使用。Haml可以輕鬆配合其他語言使用。下列是各種語言對Haml的實現:
- hamlit (Ruby)(頁面存檔備份,存於網際網路檔案館)
- HamlPy (Python)(頁面存檔備份,存於網際網路檔案館)
- LuaHaml (Lua)(頁面存檔備份,存於網際網路檔案館)
- MonoRail NHaml (ASP.NET)
- NHaml (.NET)(頁面存檔備份,存於網際網路檔案館)
- Fammel (PHP)
- HAML-TO-PHP (PHP5)
- pHAML (PHP)(頁面存檔備份,存於網際網路檔案館)
- phamlp (PHP)(頁面存檔備份,存於網際網路檔案館)
- phpHaml (PHP5)(頁面存檔備份,存於網際網路檔案館)
- Multi target HAML (PHP5.3)(頁面存檔備份,存於網際網路檔案館)
- haml-js (JavaScript)(頁面存檔備份,存於網際網路檔案館)
- Text::Haml (Perl)(頁面存檔備份,存於網際網路檔案館)
- Scalate (Scala)
- JHaml (Java)(頁面存檔備份,存於網際網路檔案館)
- Hart (Dart)(頁面存檔備份,存於網際網路檔案館)
- cl-haml (Common Lisp)(頁面存檔備份,存於網際網路檔案館)
參見
編輯參考資料
編輯- ^ Release 6.3.0. 2023年12月10日 [2023年12月19日].
- ^ 2.0 2.1 GitHub. [30 January 2016]. (原始內容存檔於2017-04-27).
- ^ Change Log. [2020-11-30]. (原始內容存檔於2015-01-05).
- ^ Encoding. [29 January 2016]. (原始內容存檔於2017-05-29).
- ^ UTF encodings. [7 February 2016]. (原始內容存檔於2019-02-16).
- ^ History. [29 January 2016]. (原始內容存檔於2017-05-27).
- ^ Using Haml. [7 February 2016]. (原始內容存檔於2017-05-29).