Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
Y
yii2
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
PSDI Army
yii2
Commits
509f5b64
Commit
509f5b64
authored
Nov 05, 2014
by
Nobuo Kihara
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
docs/guide-ja/structure-views.md - completed [ci skip]
parent
398d62a4
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
74 additions
and
72 deletions
+74
-72
structure-views.md
docs/guide-ja/structure-views.md
+74
-72
No files found.
docs/guide-ja/structure-views.md
View file @
509f5b64
...
@@ -581,20 +581,20 @@ Yii 縺ッ闊槫床陬上〒莠後▽縺ョ繧ケ繝ャ繝励r霍オ繧薙〒縲∫音螳壹繧ウ繝ウ繝医Ο繝シ
...
@@ -581,20 +581,20 @@ Yii 縺ッ闊槫床陬上〒莠後▽縺ョ繧ケ繝ャ繝励r霍オ繧薙〒縲∫音螳壹繧ウ繝ウ繝医Ο繝シ
*
[
テーマ
](
output-theming.md
)
: ウェブサイトのテーマを開発し変更することを可能にします。
*
[
テーマ
](
output-theming.md
)
: ウェブサイトのテーマを開発し変更することを可能にします。
*
[
フラグメントキャッシュ
](
caching-fragment.md
)
: ウェブページの中の断片をキャッシュすることを可能にします。
*
[
フラグメントキャッシュ
](
caching-fragment.md
)
: ウェブページの中の断片をキャッシュすることを可能にします。
*
[
クライアントスクリプトの取り扱い
](
output-client-scripts.md
)
: CSS と JavaScript の登録とレンダリングをサポートします。
*
[
クライアントスクリプトの取り扱い
](
output-client-scripts.md
)
: CSS と JavaScript の登録とレンダリングをサポートします。
*
[
アセットバンドルの取り扱い
](
structure-assets.md
)
:
[
アセットバンドル
](
structure-assets.md
)
の登録とレンダリングをサポート.
*
[
アセットバンドルの取り扱い
](
structure-assets.md
)
:
[
アセットバンドル
](
structure-assets.md
)
の登録とレンダリングをサポートします。
*
[
alternative template engines
](
tutorial-template-engines.md
)
: allows you to use other template engines, such as
*
[
代替のテンプレートエンジン
](
tutorial-template-engines.md
)
:
[
Twig
](
http://twig.sensiolabs.org/
)
、
[
Smarty
](
http://www.smarty.net/
)
など、他のテンプレートエンジンを使用することを可能にします。
[
Twig
](
http://twig.sensiolabs.org/
)
,
[
Smarty
](
http://www.smarty.net/
)
.
You may also frequently use the following minor yet useful features when you are developing Web pages.
次に挙げるマイナーではあっても有用な諸機能は、ウェブページを開発するときに頻繁に使用するでしょう:
###
Setting Page Titles
<a name="setting-page-titles"></a>
###
ページタイトルを設定する <a nam
e="setting-page-titles"></a>
Every Web page should have a title. Normally the title tag is being displayed in a
[
layout
](
#layouts
)
. However, in practice
どんなウェブページにもタイトルが無ければなりません。通常、タイトルタグは
[
layout
](
#layouts
)
の中で表示されます。しかし、
the title is often determined in content views rather than layouts. To solve this problem,
[
[yii\web\View
]
] provides
実際においては、多くの場合、タイトルはレイアウトではなくコンテンツビューで決められます。この問題を解決するために、
the
[
[yii\web\View::title|title
]
] property for you to pass the title information from content views to layouts.
[
[yii\web\View
]
] は、タイトル情報をコンテンツビューからレイアウトに渡すための
[
[yii\web\View::title|title
]
] プロパティを
提供しています。
To make use of this feature, in each content view, you can set the page title like the following
:
この機能を利用するためには、全てのコンテンツビューにおいて、次のようにタイトルを設定します:
```
php
```
php
<?php
<?php
...
@@ -602,20 +602,20 @@ $this->title = 'My page title';
...
@@ -602,20 +602,20 @@ $this->title = 'My page title';
?>
?>
```
```
Then in the layout, make sure you have the following code in the
`<head>`
section
:
そして、レイアウトビューで、
`<head>`
セクションに次のコードを忘れずに書くようにします:
```
php
```
php
<title>
<?=
Html
::
encode
(
$this
->
title
)
?>
</title>
<title>
<?=
Html
::
encode
(
$this
->
title
)
?>
</title>
```
```
###
Registering Meta Tags
<a name="registering-meta-tags"></a>
###
メタタグを登録する <a nam
e="registering-meta-tags"></a>
Web pages usually need to generate various meta tags needed by different parties. Like page titles, meta tags
ウェブページは、通常、いろいろな関係者によって必要とされるさまざまなメタタグを生成する必要があります。ページタイトルと同じように、
appear in the
`<head>`
section and are usually generated in layouts.
メタタグは
`<head>`
セクションに出現して、通常はレイアウトの中で生成されます。
If you want to specify what meta tags to generate in content views, you can call
[
[yii\web\View::registerMetaTag()
]
]
どのようなメタタグを生成するかをコンテンツビューの中で指定したい場合は、下記のように、
in a content view, like the following
:
[
[yii\web\View::registerMetaTag()
]
] をコンテンツビューの呼ぶことが出来ます:
```
php
```
php
<?php
<?php
...
@@ -623,67 +623,69 @@ $this->registerMetaTag(['name' => 'keywords', 'content' => 'yii, framework, php'
...
@@ -623,67 +623,69 @@ $this->registerMetaTag(['name' => 'keywords', 'content' => 'yii, framework, php'
?>
?>
```
```
The above code will register a "keywords" meta tag with the view component. The registered meta tag is
上記のコードは、ビューコンポーネントによって "keywords" メタタグを登録するものです。登録されたメタタグは、
rendered after the layout finishes rendering. By then, the following HTML code will be inserted
レイアウトがレンダリングを完了した後でレンダリングされます。すなわち、レイアウトの中で
[
[yii\web\View::head()
]
]
at the place where you call
[
[yii\web\View::head()
]
] in the layout and generate the following HTML code
:
を呼び出した場所に、次の HTML コードが生成されて挿入されます:
```
php
```
php
<meta
name=
"keywords"
content=
"yii, framework, php"
>
<meta
name=
"keywords"
content=
"yii, framework, php"
>
```
```
Note that if you call
[
[yii\web\View::registerMetaTag()
]
] multiple times, it will register multiple meta tags,
[
[yii\web\View::registerMetaTag()
]
] を複数回呼び出した場合は、メタタグが同じものか否かに関係なく、
regardless whether the meta tags are the same or not.
複数のメタタグが登録されることに注意してください。
To make sure there is only a single instance of a meta tag type, you can specify a key as a second parameter when calling the method.
ある型のメタタグのインスタンスが一つだけになることを保証したい場合は、このメソッドを呼ぶときに第二のパラメータとして
For example, the following code registers two "description" meta tags. However, only the second one will be rendered.
キーを指定することが出来ます。例えば、次のコードでは、二つの "description" メタタグを登録していますが、
二番目のものだけがレンダリングされることになります。
```
html
```
html
$this->registerMetaTag(['name' => 'description', 'content' => '
This is my cool website made with Yii
!'], 'description');
$this->registerMetaTag(['name' => 'description', 'content' => '
俺が Yii で作ったクールなウェブサイトだぜぃ!!'], 'descrip
tion');
$this->registerMetaTag(['name' => 'description', 'content' => '
This website is about funny raccoons.
'], 'description');
$this->registerMetaTag(['name' => 'description', 'content' => '
面白いアライグマに関するウェブサイトです。'], 'descript
ion');
```
```
###
Registering Link Tags
<a name="registering-link-tags"></a>
###
リンクタグを登録する <a name
="registering-link-tags"></a>
Like
[
meta tags
](
#adding-meta-tags
)
, link tags are useful in many cases, such as customizing favicon, pointing to
[
メタタグ
](
#registering-meta-tags
)
と同じように、リンクタグも多くの場合において有用なものです。例えば、favicon をカスタマイズしたり、
RSS
feed or delegating OpenID to another server. You can work with link tags in the similar way as meta tags
RSS
フィードを指し示したり、OpenID を別のサーバに委任したり、等々。リンクタグも、
[
[yii\web\View::registerLinkTag()
]
] を使って、
by using
[
[yii\web\View::registerLinkTag()
]
]. For example, in a content view, you can register a link tag like follows,
メタタグと同じような方法で取り扱うことが出来ます。例えば、コンテンツビューにおいて、次のようにしてリンクタグを登録することが出来ます。
```
php
```
php
$this
->
registerLinkTag
([
$this
->
registerLinkTag
([
'title'
=>
'
Live News for Yii
'
,
'title'
=>
'
Yii ライブニューズ'
,
'rel'
=>
'alternate'
,
'rel'
=>
'alternate'
,
'type'
=>
'application/rss+xml'
,
'type'
=>
'application/rss+xml'
,
'href'
=>
'http://www.yiiframework.com/rss.xml/'
,
'href'
=>
'http://www.yiiframework.com/rss.xml/'
,
]);
]);
```
```
The code above will result in
上記のコードは、次の結果になります。
```
html
```
html
<link
title=
"
Live News for Yii
"
rel=
"alternate"
type=
"application/rss+xml"
href=
"http://www.yiiframework.com/rss.xml/"
>
<link
title=
"
Yii ライブニューズ"
rel=
"alternate"
type=
"application/rss+xml"
href=
"http://www.yiiframework.com/rss.xml/"
>
```
```
Similar as
[
[yii\web\View::registerMetaTag()|registerMetaTags()
]
], you can specify a key when calling
[
[yii\web\View::registerMetaTag()|registerMetaTags()
]
] と同じように、
[
[yii\web\View::registerLinkTag()|registerLinkTag()
]
]
[
[yii\web\View::registerLinkTag()|registerLinkTag()
]
] to avoid generated repeated link tags.
を呼ぶときにキーを指定すると、同じリンクタグを繰り返して生成するのを避けることが出来ます。
##
View Events
<a name="view-events"></a>
##
ビューのイベント <a n
ame="view-events"></a>
[
[yii\base\View|View components
]
] trigger several events during the view rendering process. You may respond
[
[yii\base\View|ビューコンポーネント
]
] はビューをレンダリングする過程においていくつかのイベントをトリガします。
to these events to inject content into views or process the rendering results before they are sent to end users.
これらのイベントに反応することによって、ビューにコンテンツを注入したり、
エンドユーザに送信される前にレンダリング結果を加工したりすることが出来ます。
-
[
[yii\base\View::EVENT_BEFORE_RENDER|EVENT_BEFORE_RENDER
]
]:
triggered at the beginning of rendering a file
-
[
[yii\base\View::EVENT_BEFORE_RENDER|EVENT_BEFORE_RENDER
]
]:
コントローラでファイルをレンダリングする前にトリガされます。
in a controller. Handlers of this event may set
[
[yii\base\ViewEvent::isValid
]
] to be false to cancel the rendering process.
このイベントのハンドラは、
[
[yii\base\ViewEvent::isValid
]
] を false にセットして、レンダリングのプロセスをキャンセルすることが出来ます。
-
[
[yii\base\View::EVENT_AFTER_RENDER|EVENT_AFTER_RENDER
]
]:
triggered after rendering a file by the call of
[
[yii\base\View::afterRender()
]
].
-
[
[yii\base\View::EVENT_AFTER_RENDER|EVENT_AFTER_RENDER
]
]:
ファイルのレンダリングの後、
[
[yii\base\View::afterRender()
]
] を呼ぶことによってトリガされます。
Handlers of this event may obtain the rendering result through
[
[yii\base\ViewEvent::output
]
] and may modify
このイベントのハンドラは、レンダリング結果を
[
[yii\base\ViewEvent::output
]
] によって取得することが出来、
this property to change the rendering result.
このプロパティを修正してレンダリング結果を変更することが出来ます。
-
[
[yii\base\View::EVENT_BEGIN_PAGE|EVENT_BEGIN_PAGE
]
]:
triggered by the call of
[
[yii\base\View::beginPage()
]
] in layouts.
-
[
[yii\base\View::EVENT_BEGIN_PAGE|EVENT_BEGIN_PAGE
]
]:
レイアウトの中で
[
[yii\base\View::beginPage()
]
] を呼ぶことによってトリガされます。
-
[
[yii\base\View::EVENT_END_PAGE|EVENT_END_PAGE
]
]:
triggered by the call of
[
[yii\base\View::endPage()
]
] in layouts.
-
[
[yii\base\View::EVENT_END_PAGE|EVENT_END_PAGE
]
]:
レイアウトの中で
[
[yii\base\View::endPage()
]
] を呼ぶことによってトリガされます。
-
[
[yii\web\View::EVENT_BEGIN_BODY|EVENT_BEGIN_BODY
]
]:
triggered by the call of
[
[yii\web\View::beginBody()
]
] in layouts.
-
[
[yii\web\View::EVENT_BEGIN_BODY|EVENT_BEGIN_BODY
]
]:
レイアウトの中で
[
[yii\web\View::beginBody()
]
] を呼ぶことによってトリガされます。
-
[
[yii\web\View::EVENT_END_BODY|EVENT_END_BODY
]
]:
triggered by the call of
[
[yii\web\View::endBody()
]
] in layouts.
-
[
[yii\web\View::EVENT_END_BODY|EVENT_END_BODY
]
]:
レイアウトの中で
[
[yii\web\View::endBody()
]
] を呼ぶことによってトリガされます。
For example, the following code injects the current date at the end of the page body
:
例えば、次のコードはページの body の最後に現在の日付を注入するものです:
```
php
```
php
\Yii
::
$app
->
view
->
on
(
View
::
EVENT_END_BODY
,
function
()
{
\Yii
::
$app
->
view
->
on
(
View
::
EVENT_END_BODY
,
function
()
{
...
@@ -692,12 +694,12 @@ For example, the following code injects the current date at the end of the page
...
@@ -692,12 +694,12 @@ For example, the following code injects the current date at the end of the page
```
```
##
Rendering Static Pages
<a name="rendering-static-pages"></a>
##
静的なページをレンダリングする <a name=
"rendering-static-pages"></a>
Static pages refer to those Web pages whose main content are mostly static without the need of accessing
静的なページというのは、主たるコンテンツのほとんどが静的なもので、コントローラからプッシュされる動的なデータに
dynamic data pushed from controllers.
アクセスする必要がないページを指します。
You can output static pages by putting their code in the view, and then using the code like the following in a controller
:
静的なページは、そのコードをビューに置き、そして、コントローラで次のようなコードを使うと表示することが出来ます:
```
php
```
php
public
function
actionAbout
()
public
function
actionAbout
()
...
@@ -706,9 +708,9 @@ public function actionAbout()
...
@@ -706,9 +708,9 @@ public function actionAbout()
}
}
```
```
If a Web site contains many static pages, it would be very tedious repeating the similar code many times.
ウェブサイトが多くの静的なページを含んでいる場合、同じようなコードを何度も繰り返すのは非常に面倒くさいでしょう。
To solve this problem, you may introduce a
[
standalone action
](
structure-controllers.md#standalone-actions
)
この問題を解決するために、
[
[yii\web\ViewAction
]
] という
[
スタンドアロンアクション
](
structure-control
lers.md#standalone-actions
)
called
[
[yii\web\ViewAction
]
] in a controller. For example,
をコントローラに導入することが出来ます。例えば、
```
php
```
php
namespace
app\controllers
;
namespace
app\controllers
;
...
@@ -728,34 +730,34 @@ class SiteController extends Controller
...
@@ -728,34 +730,34 @@ class SiteController extends Controller
}
}
```
```
Now if you create a view named
`about`
under the directory
`@app/views/site/pages`
, you will be able to
このようにすると、ディレクトリ
`@app/views/site/pages`
の下に
`about`
という名前のビューを作成したときに、
display this view by the following URL
:
次の URL によってこのビューを表示することが出来るようになります:
```
```
http://localhost/index.php?r=site/page&view=about
http://localhost/index.php?r=site/page&view=about
```
```
The
`GET`
parameter
`view`
tells
[
[yii\web\ViewAction
]
] which view is requested. The action will then look
`view`
という
`GET`
パラメータが、どのビューがリクエストされているかを
[
[yii\web\ViewAction
]
] に教えます。
for this view under the directory
`@app/views/site/pages`
. You may configure
[
[yii\web\ViewAction::viewPrefix
]
]
そこで、アクションはこのビューをディレクトリ
`@app/views/site/pages`
の下で探します。
to change the directory for searching these views.
[
[yii\web\ViewAction::viewPrefix
]
] を構成して、ビューを探すディレクトリを変更することが出来ます。
##
Best Practices
<a name="best-practices"></a>
##
最善の慣行
<a name="best-practices"></a>
Views are responsible for presenting models in the format that end users desire. In general, views
ビューはエンドユーザが望む形式でモデルを表現することに対して責任を持ちます。一般的に、ビューは
*
should mainly contain presentational code, such as HTML, and simple PHP code to traverse, format and render data.
*
主として表示目的のコードを含むべきです。例えば、HTML、そしてデータをたどり、書式化してレンダリングする簡単な PHP コードなど。
*
should not contain code that performs DB queries. Such code should be done in models.
*
DB クエリを実行するコードは含むべきではありません。そのようなコードはモデルの中で実行されるべきです。
*
should avoid direct access to request data, such as
`$_GET`
,
`$_POST`
. This belongs to controllers.
*
`$_GET`
や
`$_POST`
のようなリクエストデータに直接アクセスするべきではありません。それはコントローラの仕事です。
If request data is needed, they should be pushed into views by controllers.
リクエストデータが必要な場合は、コントローラからビューにプッシュされるべきです。
*
may read model properties, but should not modify them.
*
モデルのプロパティを読み出すことが出来ます。しかし、それを修正するべきではありません。
To make views more manageable, avoid creating views that are too complex or contain too much redundant code.
ビューを管理しやすいものにするために、複雑すぎるビューや、冗長なコードをあまりに多く含むビューを作ることは避けましょう。
You may use the following techniques to achieve this goal
:
この目的を達するために、次のテクニックを使うことが出来ます:
*
use
[
layouts
](
#layouts
)
to represent common presentational sections (e.g. page header, footer).
*
共通の表示セクション (ページのヘッダやフッタなど) を表すために
[
レイアウト
](
#layouts
)
を使う。
*
divide a complicated view into several smaller ones. The smaller views can be rendered and assembled into a bigger
*
複雑なビューはいくつかの小さなビューに分割する。既に説明したレンダリングのメソッドを使えば、
one using the rendering methods that we have described.
小さなビューをレンダリングして大きなビューを組み上げることが出来る。
*
create and use
[
widgets
](
structure-widgets.md
)
as building blocks of views.
*
ビューの構成要素として
[
ウィジェット
](
structure-widgets.md
)
を使う。
*
create and use helper classes to transform and format data in views.
*
ビューでデータを変換し書式化するためのヘルパークラスを作成して使う。
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment