Вход/Регистрация
Программирование на языке Ruby
вернуться

Фултон Хэл

Шрифт:

<html>

 <head>

<title>Nitro!</title>

 </head>

 <body>

<h1>The Ruby Way</h1>

<h2>Hal Fulton</h2>

Page last updated: #{Time.now}

 </body>

</html>

После перезагрузки страницы вы увидите текущие дату и время. Nitro также поддерживает синтаксис команд обработки, принятый в XML:

<?r curr_date = Time.new.strftime( "%a, %b %d, %Y") ?>

<html>

 <head>

<title>Nitro!</title>

 </head>

 <body>

<h1>The Ruby Way</h1>

<h2>Hal Fulton</h2>

Page last updated: #{curr_date}

 </body>

</html>

Отметим, что из наличия синтаксиса

<?r ... ?>
не следует, что весь шаблон должен подчиняться правилам XML. Nitro располагает средствами для обработки шаблонов как XML-документов, а такой синтаксис позволяет иметь шаблоны, которые одновременно являются корректными XML-документами.

19.4.2. Nitro и паттерн MVC

Вставка кода непосредственно в шаблон удобна для экспериментов и перехода со статических страниц на динамические. Но со временем обнаруживается, что тестировать и сопровождать такое приложение становится все сложнее. Паттерн Модель-Вид-Контроллер позволяет упростить жизнь за счет переноса кода в классы Ruby.

Начнем с создания класса контроллера

main.rb
. Если в каталоге приложения есть папка
src
, Nitro добавит ее в список путей, по которым ищутся страницы. Следуя принятым в Nitro соглашениям, создадим файл
<app_root>/src/controller/book.rb
:

class BookController

 def index

@author = "Hal Fulton"

@title = "The Ruby Way"

@last_update = Time.new

 end

end

Изменим файл

index.xhtml
, включив в него ссылки на эти переменные:

<html>

 <head>

<title>Nitro!</title>

 </head>

 <body>

<h1>#{@title}</h1>

<h2>#{@author}</h2>

Page last updated: #{@last_update}

 </body>

</html>

Придется также немного подправить файл

run.rb
:

require 'nitro'

require 'controller/book'

Nitro.run(BookController)

Перезапустите сервер WEBrick и перезагрузите страницу, чтобы посмотреть на результат.

Отметим несколько вещей. Файлы шаблонов могут остаться в папке

public
; класс контроллера не обязан расширять какой-то специальный базовый класс; класс, переданный методу
Nitro.run
, автоматически сопоставляется с корневым URL приложения. Все эти аспекты конфигурируемы.

По умолчанию Nitro ищет шаблоны в каталогах

template
и
public
. Если вы не хотите помещать шаблоны в каталог
public
(скажем, потому, что предпочитаете зарезервировать его только для статических HTML-файлов), то можете создать каталог
template
и хранить их там. Предполагается, что пути к шаблонам повторяют пути, заданные в URL, относительно корневой папки шаблонов. Наш файл
index.xhtml
мог бы храниться как
public/index.xhtml
или
template/index.xhtml
. Использование каталога
public
упрощает переход от статического сайта к динамическому, но лучше организовать раздельное хранение статических файлов и шаблонов.

Классы контроллеров могут отображаться на пути URL с помощью файла

Server.map
. Например, наше демонстрационное приложение может содержать статическую главную страницу со списком литературы (в котором на данный момент присутствует всего одна книга), находящуюся совсем по другому пути. Для этого нужно следующим образом изменить файл
run.rb
:

require 'nitro'

require 'controller/book'

Nitro::Server.map = { '/books' => BookController }

  • Читать дальше
  • 1
  • ...
  • 301
  • 302
  • 303
  • 304
  • 305
  • 306
  • 307
  • 308
  • 309
  • 310
  • 311
  • ...

Ебукер (ebooker) – онлайн-библиотека на русском языке. Книги доступны онлайн, без утомительной регистрации. Огромный выбор и удобный дизайн, позволяющий читать без проблем. Добавляйте сайт в закладки! Все произведения загружаются пользователями: если считаете, что ваши авторские права нарушены – используйте форму обратной связи.

Полезные ссылки

  • Моя полка

Контакты

  • chitat.ebooker@gmail.com

Подпишитесь на рассылку: