Haml

Haml (HTML Abstraction Markup Language) — це мова для написання шаблонів, головною метою якої є написання простого і легкого для сприйняття коду, який інтерпретується в звичайний HTML. Haml дає змогу писати динамічний код для HTML. Аналогічно іншим мовам програмування для вебу, таких як PHP, ASP, JSP та шаблонних систем типа eRuby, Haml також дозволяє писати код, що буде виконаний протягом генерації HTML і отримати динамічний код. Розширення файлів з кодом − .haml. Такий підхід до роботи схожий на файли .erb (eRuby), що дозволяють вставляти код, написаний на Ruby для генерації коду веб-застосунків. Під час обробки коду Haml користується тими ж правилами, що й Ruby версії 1.9 і новіше. Haml розпізнає тільки кодування, сумісні з ASCII, такі як UTF-8, але при цьому не працює з UTF-16 чи UTF-32 через те, що вони несумісні з ASCII.[3][4] Haml може працювати через командний рядок як окремий модуль Ruby або ж використовуватися в Ruby on Rails, що робить цю мову гнучкою та зручною для створення багатьох видів застосунків.

Haml
Парадигма Мова для шаблонів
Творці Нік Волш
Розробник Норман Кларк, Мет Вайлдіґ, Акіра Мацуда, Ті Перхем
Останній реліз 4.0.7 (10 серпня 2015)
Операційна система Крос-платформова
Ліцензія MIT License,[1] Unspace Interactive.[2]
Звичайні розширення файлів .haml
Репозиторій вихідного коду github.com/haml/haml
Вебсайт haml.info

Історія

Haml було створено Гемптоном Кетліном у 2006 р.[5] Його метою було спрощення написання і редагування коду на HTML. З 2006 року вийшло кілька оновлених версій цієї мови. У квітні 2012-го роботу над Haml взяв на себе Норман Кларк.[5] Наталі Вайзенбаум та Нік Волш допомагали вдосконалювати мову і продовжують підтримувати її розвиток. Наталі працювала над тим, щоб HAML був сусісним з застосунками на Ruby, а дизайном та брендінґом займався Нік.[5] Також над проектом працюють Мет Вілдіґ, Акіра Мацуда and Ті Пергем.[2]

Особливості

Haml базується на чотирьох принципах.[5]

Розмітка, яку легко читати

Розмітка коду цією мовою має відповідати наступним правилам:

  • Легко розуміти
  • Легко використовувати

DRY

Розмітка має відповідати принципу DRY. Вона має:

  • Уникати непотрібних повторень
  • Приділяти увагу чистоті коду

Прості відступи

Мову розмітки зі зручними відступами легко читати і відразу бачити початок та кінець коду елементів.

Зрозуміла структура

Зрозуміла структура коду допомагає легко його масштабувати і редагувати.

Приклади

Розмітка Haml дуже схожа на синтаксис CSS. Наприклад, в Haml символ . відповідає за визначення класів, як це робиться в CSS.

Приклад «Hello, World»

Просте рішення для  Hello World на Haml виглядатиме так:

Haml as a Command-line tool

%p{:class => "sample", :id => "welcome"} Hello, World!

Що буде екпортовано в наступний HTML:

<p class="sample" id="welcome">Hello, World!</p>

Щоб запустити код Haml, потрібно інсталювати Haml за допомогою gem:[6]

gem install haml

Код Haml, що збережений у файл Hello.haml, можна запустити наступним чином:

haml Hello.haml

Haml у вигляді джема для Ruby on Rails

Щоб використовувати Haml з Ruby, файл Gemfile має включати наступний рядок:

gem 'haml'

Аналогічно до мови ERB, Haml також може оперувати локальними змінними, що задекларовані в тому ж файлі в Ruby-коді. Цей код містить приклад коду контролера Ruby.[6]

  • файл: app/controllers/messages_controller.rb
    class MessagesController < ApplicationController
      def index
        @message = "Hello, World!"
      end
    end
    
  • файл: app/views/messages/index.html.haml
    #welcome
        %p= @message
    
    Буде скомпільовано в:
    <div id="welcome">
        <p>Hello, World!</p>
    </div>
    

Haml як модуль Ruby

Щоб користуватись Haml окремо від Rails та ActionView, інсталюйте haml за допомогою gem, включіть його до Gemfile, а далі імпортуйте [Usage: require 'haml'] до скрипту на Ruby або запустіть інтерпретатор Ruby за допомогою -rubygems.

welcome = Haml::Engine.new("%p Hello, World!")
welcome.render

Результат:

<p>Hello, World!</p>

Haml::Engine є класом Haml.

Приклад

Haml використовує відступи у вигляді двох пробілів для створення вкладених тегів. Це служить еквівалентом відкриттю і закриттю парних тегів у HTML, притримуючись методу DRY, роблячи код простим і легким для читання. Наступний приклад показує відмінності між Haml та ERB (з використанням 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 немає закриття тегів, як у ERB
  • Синтакс ERB дуже схожий на HTML, в той час як Haml більше схожий на CSS.
  • Haml використовує відступи для створення структури елементів-тегів, а ERB має схожий на HTML синтаксис.
  • Властивості Haml, такі як class і id можна призначати за допомогою символів # та .  відповідно. Також можна використовувати атрибути class та id, що не є необхідним. Haml також використовує символ %, щоб відокремити елемент HTML замість кутових дужок <>, як це робить ERB.

Приклад з вкрапленням 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 можна легко використовувати з іншими мовами. Нижче наведено список мов, в яких є можливість імплементації коду HAML:

Див. також

Додаткові матеріали

Примітки

  1. MIT License. Процитовано 15 лютого 2016.
  2. GitHub. Процитовано 30 січня 2016.
  3. Encoding. Процитовано 29 січня 2016.
  4. UTF encodings. Процитовано 7 лютого 2016.
  5. History. Процитовано 29 січня 2016.
  6. Using Haml. Процитовано 7 лютого 2016.

Посилання


This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.