объявление относительно переменной содержимого

Я новая пьеса. Я просматривал учебные пособия и образцы, предоставленные игровым фреймворком. Я смог успешно отрендерить приложение helloworld, предоставленное образцами playframework. У меня мало сомнений относительно части рендеринга main.scala.html.#

Это программа по умолчанию, которую я получил из samples/helloworld.

@(title: String)(content: Html)

<!DOCTYPE html>

<html>
    <head>
        <title>@title</title>
        <link rel="stylesheet" media="screen" href="@routes.Assets.at("stylesheets/main.css")">
        <link rel="shortcut icon" type="image/png" href="@routes.Assets.at("images/favicon.png")">
        <script src="@routes.Assets.at("javascripts/jquery-1.6.4.min.js")" type="text/javascript"></script>
    </head>
    <body>

        <header>
            <a href="@routes.Application.index">@title</a>
        </header>

        <section>
            @content
        </section>

    </body>
</html>

Здесь, когда я закомментировал @content под тегом раздела, я не вижу поля. Теперь мой вопрос: где @content отображается в поле формы?

Я создал другую структуру для своего макета и добавил @content в раздел контента. но это не вписывается в это, поэтому теперь мой вопрос: @content, где это определено, что это контейнер div и имеет некоторую высоту, вес и все такое? Я не мог понять. Помогите пожалуйста мне. Пожалуйста, найдите мой индивидуальный код ниже

@(title: String)(content: Html)

<!DOCTYPE html>

<html>
    <head>
        <title>@title</title>
        <link rel="stylesheet" media="screen" href="@routes.Assets.at("stylesheets/main.css")">
        <link rel="shortcut icon" type="image/png" href="@routes.Assets.at("images/favicon.png")">
        <script src="@routes.Assets.at("javascripts/jquery-1.7.1.min.js")" type="text/javascript"></script>
    </head>


<body>

<div id="container" style="width:500px">

<div id="header" style="background-color:#FFA500;">
<h1 style="margin-bottom:0;">Main Title of Web Page</h1></div>

<div id="menu" style="background-color:#FFD700;height:200px;width:100px;float:left;">
<b>Menu</b><br>
HTML<br>
CSS<br>
JavaScript</div>

<div id="content" style="background-color:#EEEEEE;height:200px;width:400px;float:left;">
@content</div>

<div id="footer" style="background-color:#FFA500;clear:both;text-align:center;">
Copyright © W3Schools.com</div>






</body>


</html>

person JavaPassion    schedule 29.05.2014    source источник


Ответы (1)


Введение

Из параметров шаблона в документации по шаблону воспроизведения описывается значение первой строки. . Здесь мы видим, что требуются две группы параметров.

Две группы параметров:

  1. параметр String, содержащий заголовок
  2. параметр Html, содержащий некоторый HTML-контент

Использование

Для использования этого шаблона необходимо указать две группы параметров. В контексте приложения helloworld оно вызывается из app/views/index.scala.html следующим образом:

@main(title = "The 'helloworld' application") {
  <h1>Configure your 'Hello world':</h1>
  ... more HTML elided
}

Этот шаблон описан в http://www.playframework.com/documentation/2.2.x/ScalaTemplateUseCases, где HTML внедряется в шаблон.

  • main.scala.html содержит шаблон (content содержит вставляемый HTML-код).
  • index.scala.html содержит пример внедрения в этот шаблон.

Обратите внимание, что вызов @main(...) вызывает шаблон, определенный в main.scala.html. Аналогично, вызов @my_template(...) вызовет шаблон, определенный в my_template.scala.html.

В этом случае HTML для формы определяется внутри index.scala.html.

Вызов шаблона

Наконец, корневой шаблон вызывается из контроллера. Для приложения helloworld шаблон, определенный в index.scala.html, вызывается кодом

def index = Action {
  Ok(html.index(helloForm))
}

Здесь объект формы вставляется в шаблон.

person Gary Coady    schedule 29.05.2014