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
3858e215
Commit
3858e215
authored
Nov 09, 2014
by
Qiang Xue
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #5989 from softark/docs-guide-ja-2014-11-10
docs/guide-ja/structure-widgets.md added [ci skip]
parents
91813a81
134f16b1
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
196 additions
and
2 deletions
+196
-2
README.md
docs/guide-ja/README.md
+0
-1
start-looking-ahead.md
docs/guide-ja/start-looking-ahead.md
+1
-1
structure-widgets.md
docs/guide-ja/structure-widgets.md
+195
-0
No files found.
docs/guide-ja/README.md
View file @
3858e215
...
...
@@ -54,7 +54,6 @@ All Rights Reserved.
*
[
リクエスト
](
runtime-requests.md
)
*
[
レスポンス
](
runtime-responses.md
)
*
[
セッションとクッキー
](
runtime-sessions-cookies.md
)
*
[
URL の解析と生成
](
runtime-url-handling.md
)
*
[
エラー処理
](
runtime-handling-errors.md
)
*
[
ログ
](
runtime-logging.md
)
...
...
docs/guide-ja/start-looking-ahead.md
View file @
3858e215
...
...
@@ -18,7 +18,7 @@ Gii をコード生成に使うと、ウェブ開発のプロセスの大部分
これは Yii によって提供される全てのクラスの使用法を記述しています。
主として、コードを書いている時に、特定のクラス、メソッド、プロパティについて理解したい場合に読まれるべきものです。
クラスリファレンスの使用は、フレームワーク全体の文脈的な理解が出来てからにするのが最善です。
-
[
Wiki の記事
](
(http://www.yiiframework.com/wiki/?tag=yii2
)
):
-
[
Wiki の記事
](
http://www.yiiframework.com/wiki/?tag=yii2
)
:
Wiki の記事は、Yii のユーザが自身の経験に基づいて書いたものです。
ほとんどの記事は、料理本のレシピのように書かれており、特定の問題を Yii を使って解決する方法を示しています。
これらの記事の品質は公式ガイドほどには良くないかもしれませんが、
...
...
docs/guide-ja/structure-widgets.md
0 → 100644
View file @
3858e215
ウィジェット
============
ウィジェットは、
[
ビュー
](
structure-views.md
)
で使用される再利用可能な構成ブロックで、
複雑かつコンフィギュレーション可能なユーザインタフェイス要素をオブジェクト指向のやり方で作成するためのものです。
例えば、日付選択ウィジェットを使うと、入力として日付を選択することを可能にする素敵なデイトピッカーを生成することが出来ます。
このとき、あなたがしなければならないことは、次のようなコードをビューに挿入することだけです:
```
php
<?php
use
yii\jui\DatePicker
;
?>
<?=
DatePicker
::
widget
([
'name'
=>
'date'
])
?>
```
数多くのウィジェットが Yii にバンドルされています。例えば、
[
[yii\widgets\ActiveForm|アクティブフォーム
]
] や、
[
[yii\widgets\Menu|メニュー
]
]、
[
jQuery UI ウィジェット
](
widget-jui.md
)
、
[
Twitter Bootstrap ウィジェット
](
widget-bootstrap.md
)
などです。
下記では、ウィジェットに関する基本的な知識の手引きをします。
特定のウィジェットの使い方について学ぶ必要がある場合は、クラス API ドキュメントを参照してください。
## ウィジェットを使う <a name="using-widgets"></a>
ウィジェットは主として
[
ビュー
](
structure-views.md
)
で使われます。
ビューでウィジェットを使うためには、
[
[yii\base\Widget::widget()
]
] メソッドを使うことが出来ます。
このメソッドは、ウィジェットを初期化するための
[
コンフィギュレーション
](
concept-configurations.md
)
配列を受け取り、ウィジェットのレンダリング結果を返します。
例えば、下記のコードは、日本語を使い、入力を
`$model`
の
`from_date`
属性に保存するように構成された日付選択ウィジェットを挿入するものです。
```
php
<?php
use
yii\jui\DatePicker
;
?>
<?=
DatePicker
::
widget
([
'model'
=>
$model
,
'attribute'
=>
'from_date'
,
'language'
=>
'ja'
,
'clientOptions'
=>
[
'dateFormat'
=>
'yy-mm-dd'
,
],
])
?>
```
ウィジェットの中には、コンテントのブロックを受け取ることが出来るものもあります。その場合、コンテントのブロックは
[
[yii\base\Widget::begin()
]
] と
[
[yii\base\Widget::end()
]
] の呼び出しの間に包むようにしなければなりません。
例えば、次のコードは
[
[yii\widgets\ActiveForm
]
] ウィジェットを使ってログインフォームを生成するものです。
このウィジェットは、
`begin()`
と
`end()`
が呼ばれる場所で、それぞれ、開始と終了の
`<form>`
タグを生成します。
その間に置かれたものは全てそのままレンダリングされます。
```
php
<?php
use
yii\widgets\ActiveForm
;
use
yii\helpers\Html
;
?>
<?php
$form
=
ActiveForm
::
begin
([
'id'
=>
'login-form'
]);
?>
<?=
$form
->
field
(
$model
,
'username'
)
?>
<?=
$form
->
field
(
$model
,
'password'
)
->
passwordInput
()
?>
<div
class=
"form-group"
>
<?=
Html
::
submitButton
(
'ログイン'
)
?>
</div>
<?php
ActiveForm
::
end
();
?>
```
[
[yii\base\Widget::widget()
]
] がウィジェットのレンダリング結果を返すのとは違って、
[
[yii\base\Widget::begin()
]
] メソッドが
ウィジェットのインスタンスを返すことに注意してください。返されたウィジェットのインスタンスを使って、ウィジェットのコンテントを
構築することが出来ます。
## ウィジェットを作成する <a name="creating-widgets"></a>
ウィジェットを作成するためには、
[
[yii\base\Widget
]
] を拡張して、
[
[yii\base\Widget::init()
]
] および/または
[
[yii\base\Widget::run()
]
]
メソッドをオーバーライドします。通常、
`init()`
メソッドはウィジェットのプロパティを正規化するコードを含むべきものであり、
`run()`
メソッドはウィジェットのレンダリング結果を生成するコードを含むべきものです。レンダリング結果は、直接に "echo"
しても、
`run()`
の返り値として文字列として返しても構いません。
次の例では、
`HelloWidget`
が
`message`
プロパティとして割り当てられたコンテントを HTML エンコードして表示します。
プロパティがセットされていない場合は、デフォルトとして "Hello World" を表示します。
```
php
namespace
app\components
;
use
yii\base\Widget
;
use
yii\helpers\Html
;
class
HelloWidget
extends
Widget
{
public
$message
;
public
function
init
()
{
parent
::
init
();
if
(
$this
->
message
===
null
)
{
$this
->
message
=
'Hello World'
;
}
}
public
function
run
()
{
return
Html
::
encode
(
$this
->
message
);
}
}
```
このウィジェットを使うために必要なことは、次のコードをビューに挿入するだけのことです。
```
php
<?php
use
app\components\HelloWidget
;
?>
<?=
HelloWidget
::
widget
([
'message'
=>
'おはよう'
])
?>
```
下記は
`HelloWidget`
の変種で、
`begin()`
と
`end()`
の間に包まれたコンテントを受け取り、それを
HTML エンコードして表示するものです。
```
php
namespace
app\components
;
use
yii\base\Widget
;
use
yii\helpers\Html
;
class
HelloWidget
extends
Widget
{
public
function
init
()
{
parent
::
init
();
ob_start
();
}
public
function
run
()
{
$content
=
ob_get_clean
();
return
Html
::
encode
(
$content
);
}
}
```
ご覧のように、
`init()`
の中で PHP の出力バッファが開始され、
`init()`
と
`run()`
の呼び出しの間の全ての出力がキャプチャされ、
`run()`
の中で処理されて返されます。
> Info|情報: [[yii\base\Widget::begin()]] を呼ぶと、ウィジェットの新しいインスタンスが作成され、ウィジェットのコンストラクタの
最後で
`init()`
メソッドが呼ばれます。
[
[yii\base\Widget::end()
]
] を呼ぶと、
`run()`
メソッドが呼ばれて、その返り値が
`end()`
によって echo されます。
次のコードは、この
`HelloWidget`
の新しい変種をどのように使うかを示すものです:
```
php
<?php
use
app\components\HelloWidget
;
?>
<?php
HelloWidget
::
begin
();
?>
... タグを含みうるコンテント ...
<?php
HelloWidget
::
end
();
?>
```
場合によっては、ウィジェットが大きな固まりのコンテントを表示する必要があるかもしれません。コンテントを
`run()`
メソッドの中に埋め込むことも出来ますが、より良い方法は、コンテントを
[
ビュー
](
structure-views.md
)
の中に置いて、
[
[yii\base\Widget::render()
]
] を呼んでレンダリングすることです。例えば、
```
php
public
function
run
()
{
return
$this
->
render
(
'hello'
);
}
```
既定では、ウィジェット用のビューは
`WidgetPath/views`
ディレクトリの中のファイルに保存すべきものです。ここで
`WidgetPath`
はウィジェットのクラスファイルを含むディレクトリを指します。したがって、上記の例では、ウィジェットクラスが
`@app/components`
に配置されていると仮定すると、
`@app/components/views/hello.php`
というビューファイルがレンダリングされる
ことになります。
[
[yii\base\Widget::getViewPath()
]
] メソッドをオーバーライドして、ウィジェットのビューファイルを含むディレクトリを
カスタマイズすることが出来ます。
## 最善の慣行 <a name="best-practices"></a>
ウィジェットはビューのコードを再利用するためのオブジェクト指向の方法です。
ウィジェットを作成するときでも、MVC パターンに従うべきです。一般的に言うと、ロジックはウィジェットクラスに保持し、
表現は
[
ビュー
](
structure-views.md
)
に保持すべきです。
ウィジェットは自己完結的に設計されるべきです。言い換えると、ウィジェットを使うときに、他に何もしないでも
ビューに挿入することが出来るようにすべきです。この要求は、ウィジェットが CSS、JavaScript、画像などの外部リソースを必要とする場合は、
扱いにくい問題になり得ます。幸いなことに、Yii はこの問題を解決するのに利用することが出来る
[
アセットバンドル
](
structure-asset-bundles.md
)
のサポートを提供しています。
ウィジェットがビューコードだけを含む場合は、
[
ビュー
](
structure-views.md
)
と非常に似たものになります。実際のところ、この場合、
両者の唯一の違いは、ウィジェットが再配布可能なクラスである一方で、ビューはアプリケーション内に保持することが望ましい
素の PHP スクリプトである、というぐらいの事です。
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