mirror of
https://github.com/yiisoft/yii2.git
synced 2025-11-08 00:47:55 +08:00
20160611
This commit is contained in:
@ -1,3 +1,4 @@
|
||||
<<<<<<< HEAD
|
||||
データフォーマッタ
|
||||
==================
|
||||
|
||||
@ -110,6 +111,95 @@ echo Yii::$app->formatter->asDate('2014-01-01'); // 出力: 2014/01/01
|
||||
これに加えて、[ICU プロジェクト](http://site.icu-project.org/) によって定義された構文を使うカスタム書式を指定することが出来ます。
|
||||
この構文を説明する ICU マニュアルが下記の URL にあります: <http://userguide.icu-project.org/formatparse/datetime>。
|
||||
別の選択肢として、`php:` という接頭辞を付けた文字列を使って、PHP の [date()](http://php.net/manual/ja/function.date.php) 関数が認識する構文を使うことも出来ます。
|
||||
=======
|
||||
データのフォーマット
|
||||
====================
|
||||
|
||||
ユーザにとってより読みやすい形式でデータを表示するために、`formatter` [アプリケーションコンポーネント](structure-application-components.md) を使ってデータをフォーマットすることが出来ます。
|
||||
デフォルトでは、フォーマッタは [[yii\i18n\Formatter]] によって実装されており、これが、日付/時刻、数字、通貨、その他のよく使われる形式にデータをフォーマットする一連のメソッドを提供します。
|
||||
このフォーマッタは次のようにして使うことが出来ます。
|
||||
|
||||
```php
|
||||
$formatter = \Yii::$app->formatter;
|
||||
|
||||
// 出力: January 1, 2014
|
||||
echo $formatter->asDate('2014-01-01', 'long');
|
||||
|
||||
// 出力: 12.50%
|
||||
echo $formatter->asPercent(0.125, 2);
|
||||
|
||||
// 出力: <a href="mailto:cebe@example.com">cebe@example.com</a>
|
||||
echo $formatter->asEmail('cebe@example.com');
|
||||
|
||||
// 出力: Yes
|
||||
echo $formatter->asBoolean(true);
|
||||
// it also handles display of null values:
|
||||
|
||||
// 出力: (Not set)
|
||||
echo $formatter->asDate(null);
|
||||
```
|
||||
|
||||
ご覧のように、これらのメソッドは全て `asXyz()` という名前を付けられており、`Xyz` がサポートされている形式を表しています。
|
||||
別の方法として、汎用メソッド [[yii\i18n\Formatter::format()|format()]] を使ってデータをフォーマットすることも出来ます。
|
||||
この方法を使うと望む形式をプログラム的に制御することが可能になりますので、[[yii\grid\GridView]] や [[yii\widgets\DetailView]] などのウィジェットでは、こちらがよく使われています。
|
||||
例えば、
|
||||
|
||||
```php
|
||||
// 出力: January 1, 2014
|
||||
echo Yii::$app->formatter->format('2014-01-01', 'date');
|
||||
|
||||
// 配列を使ってフォーマットメソッドのパラメータを指定することも出来ます。
|
||||
// `2` は asPercent() メソッドの $decimals パラメータの値です。
|
||||
// 出力: 12.50%
|
||||
echo Yii::$app->formatter->format(0.125, ['percent', 2]);
|
||||
```
|
||||
|
||||
> Note: フォーマッタコンポーネントは、エンドユーザへの表示用に値をフォーマットすることを目的に設計されています。
|
||||
> ユーザの入力を機械が読み取れる形式にフォーマットしたい場合、また、日付を機械が読み取れる形式にフォーマットしたいだけ、という場合には、
|
||||
> フォーマッタは適切なツールではありません。
|
||||
> 日付と数値についてユーザ入力を変換するためには、それぞれ、[[yii\validators\DateValidator]] と [[yii\validators\NumberValidator]]
|
||||
> を使うことが出来ます。機械が読み取れる日付と時刻のフォーマットの単純な相互変換には、PHP の [date()](http://php.net/manual/ja/function.date.php) 関数で十分です。
|
||||
|
||||
## フォーマッタを構成する <span id="configuring-formater"></span>
|
||||
|
||||
[アプリケーションの構成情報](concept-configurations.md#application-configurations) の中で `formatter` コンポーネントを構成して、フォーマットの規則をカスタマイズすることが出来ます。
|
||||
例えば、
|
||||
|
||||
|
||||
```php
|
||||
return [
|
||||
'components' => [
|
||||
'formatter' => [
|
||||
'dateFormat' => 'dd.MM.yyyy',
|
||||
'decimalSeparator' => ',',
|
||||
'thousandSeparator' => ' ',
|
||||
'currencyCode' => 'EUR',
|
||||
],
|
||||
],
|
||||
];
|
||||
```
|
||||
|
||||
構成可能なプロパティについては、[[yii\i18n\Formatter]] を参照してください。
|
||||
|
||||
|
||||
## 日付と時刻の値をフォーマットする <span id="date-and-time"></span>
|
||||
|
||||
フォーマッタは日付と時刻に関連した下記の出力形式をサポートしています。
|
||||
|
||||
- [[yii\i18n\Formatter::asDate()|date]] - 値は日付としてフォーマットされます。例えば `January 01, 2014`。
|
||||
- [[yii\i18n\Formatter::asTime()|time]] - 値は時刻としてフォーマットされます。例えば `14:23`。
|
||||
- [[yii\i18n\Formatter::asDatetime()|datetime]] - 値は日付および時刻としてフォーマットされます。例えば `January 01, 2014 14:23`。
|
||||
- [[yii\i18n\Formatter::asTimestamp()|timestamp]] - 値は [unix タイムスタンプ](http://en.wikipedia.org/wiki/Unix_time) としてフォーマットされます。例えば `1412609982`。
|
||||
- [[yii\i18n\Formatter::asRelativeTime()|relativeTime]] - 値は、その日時と現在との間隔として、人間に分かりやすい言葉でフォーマットされます。例えば `1 hour ago`。
|
||||
- [[yii\i18n\Formatter::asDuration()|duration]] - 値は継続時間として、人間に分かりやすい言葉でフォーマットされます。例えば `1 day, 2 minutes`。
|
||||
|
||||
|
||||
[[yii\i18n\Formatter::asDate()|date]]、[[yii\i18n\Formatter::asTime()|time]]、[[yii\i18n\Formatter::asDatetime()|datetime]] メソッドに使われるデフォルトの日時書式は、フォーマッタの [[yii\i18n\Formatter::$dateFormat|$dateFormat]]、[[yii\i18n\Formatter::$timeFormat|$timeFormat]]、[[yii\i18n\Formatter::$datetimeFormat|$datetimeFormat]] を構成することで、グローバルにカスタマイズすることが出来ます。
|
||||
|
||||
日付と時刻のフォーマットは、[ICU 構文](http://userguide.icu-project.org/formatparse/datetime) によって指定することが出来ます。
|
||||
また、ICU 構文と区別するために `php:` という接頭辞を付けて、[PHP の date() 構文](http://php.net/manual/ja/function.date.php) を使うことも出来ます。
|
||||
例えば、
|
||||
>>>>>>> master
|
||||
|
||||
```php
|
||||
// ICU 形式
|
||||
@ -118,6 +208,7 @@ echo Yii::$app->formatter->asDate('now', 'yyyy-MM-dd'); // 2014-10-06
|
||||
echo Yii::$app->formatter->asDate('now', 'php:Y-m-d'); // 2014-10-06
|
||||
```
|
||||
|
||||
<<<<<<< HEAD
|
||||
### タイムゾーン <span id="time-zones"></span>
|
||||
|
||||
日時の値をフォーマットするときに、Yii はその値を [[yii\i18n\Formatter::timeZone|設定されたタイムゾーン]] に変換します。
|
||||
@ -136,10 +227,64 @@ echo Yii::$app->formatter->asTime('2014-10-06 21:41:00 JST'); // 21:41:00
|
||||
[[yii\i18n\Formatter::defaultTimeZone]] を設定して、データストレージに使用しているタイムゾーンに合わせることが出来ます。
|
||||
|
||||
> Note|注意: タイムゾーンは世界中のさまざまな政府によって作られる規則に従うものであり、頻繁に変更されるものであるため、あなたのシステムにインストールされたタイムゾーンのデータベースが最新の情報を持っていない可能性が大いにあります。
|
||||
=======
|
||||
複数の言語をサポートする必要があるアプリケーションを扱う場合には、ロケールごとに異なる日付と時刻のフォーマットを指定しなければならないことがよくあります。
|
||||
この仕事を単純化するためには、(`long`、`short` などの) フォーマットのショートカットを代りに使うことが出来ます。
|
||||
フォーマッタは、現在アクティブな [[yii\i18n\Formatter::locale|locale]] に従って、フォーマットのショートカットを適切なフォーマットに変換します。
|
||||
フォーマットのショートカットとして、次のものがサポートされています
|
||||
(例は `en_GB` がアクティブなロケールであると仮定したものです)。
|
||||
|
||||
- `short`: 日付は `06/10/2014`、時刻は `15:58` を出力
|
||||
- `medium`: `6 Oct 2014` と `15:58:42` を出力
|
||||
- `long`: `6 October 2014` と `15:58:42 GMT` を出力
|
||||
- `full`: `Monday, 6 October 2014` と `15:58:42 GMT` を出力
|
||||
|
||||
> Info: ja_JP ロケールでは、次のようになります。
|
||||
>
|
||||
> short: 2014/10/06 と 15:58
|
||||
> medium: 2014/10/06 と 15:58:42
|
||||
> long: 2014年10月6日 と 15:58:42 JST
|
||||
> full: 2014年10月6日月曜日 と 15時58分42秒 日本標準時
|
||||
|
||||
バージョン 2.0.7 以降では、さまざまな暦法に従って日付をフォーマットすることが可能です。
|
||||
通常のグレゴリオ暦とは異なる暦法を使用する方法については、フォーマッタの [[yii\i18n\Formatter::$calendar|$calendar]]
|
||||
プロパティの API ドキュメントを参照して下さい。
|
||||
|
||||
|
||||
### タイムゾーン <span id="time-zones"></span>
|
||||
|
||||
日時の値をフォーマットするときに、Yii はその値をターゲット [[yii\i18n\Formatter::timeZone|タイムゾーン]] に変換します。
|
||||
フォーマットされる値は、タイムゾーンが明示的に指定されるか、[[yii\i18n\Formatter::defaultTimeZone]] が構成されるかしていない限り、UTC であると見なされます。
|
||||
|
||||
次の例では、ターゲット [[yii\i18n\Formatter::timeZone|タイムゾーン]] が `Europe/Berlin` に設定されているものとします。
|
||||
|
||||
```php
|
||||
// UNIX タイムスタンプを時刻としてフォーマット
|
||||
echo Yii::$app->formatter->asTime(1412599260); // 14:41:00
|
||||
|
||||
// UTC の日付時刻文字列を時刻としてフォーマット
|
||||
echo Yii::$app->formatter->asTime('2014-10-06 12:41:00'); // 14:41:00
|
||||
|
||||
// CEST の日付時刻文字列を時刻としてフォーマット
|
||||
echo Yii::$app->formatter->asTime('2014-10-06 14:41:00 CEST'); // 14:41:00
|
||||
```
|
||||
|
||||
> Info:
|
||||
> ターゲット [[yii\i18n\Formatter::timeZone|タイムゾーン]] が `Asia/Tokyo` である場合は、次のようになります。
|
||||
>
|
||||
> ```php
|
||||
> echo Yii::$app->formatter->asTime(1412599260); // 21:41:00
|
||||
> echo Yii::$app->formatter->asTime('2014-10-06 12:41:00'); // 21:41:00
|
||||
> echo Yii::$app->formatter->asTime('2014-10-06 21:41:00 JST'); // 21:41:00
|
||||
> ```
|
||||
|
||||
> Note: タイムゾーンは世界中のさまざまな政府によって作られる規則に従うものであり、頻繁に変更されるものであるため、あなたのシステムにインストールされたタイムゾーンのデータベースが最新の情報を持っていない可能性が大いにあります。
|
||||
>>>>>>> master
|
||||
> タイムゾーンデータベースの更新についての詳細は、[ICU マニュアル](http://userguide.icu-project.org/datetime/timezone#TOC-Updating-the-Time-Zone-Data) で参照することが出来ます。
|
||||
> [PHP 環境を国際化のために設定する](tutorial-i18n.md#setup-environment) も参照してください。
|
||||
|
||||
|
||||
<<<<<<< HEAD
|
||||
数値をフォーマットする <span id="numbers"></span>
|
||||
----------------------
|
||||
|
||||
@ -147,6 +292,14 @@ echo Yii::$app->formatter->asTime('2014-10-06 21:41:00 JST'); // 21:41:00
|
||||
|
||||
- [[yii\i18n\Formatter::asInteger()|integer]] - 値は整数としてフォーマットされます。例えば `42`。
|
||||
- [[yii\i18n\Formatter::asDecimal()|decimal]] - 値は小数点と三桁ごとの区切りを使って十進数としてフォーマットされます。例えば `2,542.123` または `2.542,123`。
|
||||
=======
|
||||
## 数値をフォーマットする <span id="numbers"></span>
|
||||
|
||||
フォーマッタは、数値に関連した下記の出力フォーマットをサポートしています。
|
||||
|
||||
- [[yii\i18n\Formatter::asInteger()|integer]] - 値は整数としてフォーマットされます。例えば `42`。
|
||||
- [[yii\i18n\Formatter::asDecimal()|decimal]] - 値は小数点と三桁ごとの区切りを考慮して十進数としてフォーマットされます。例えば `2,542.123` または `2.542,123`。
|
||||
>>>>>>> master
|
||||
- [[yii\i18n\Formatter::asPercent()|percent]] - 値は百分率としてフォーマットされます。例えば `42%`。
|
||||
- [[yii\i18n\Formatter::asScientific()|scientific]] - 値は科学記法による数値としてフォーマットされます。例えば `4.2E4`。
|
||||
- [[yii\i18n\Formatter::asCurrency()|currency]] - 値は通貨の値としてフォーマットされます。例えば `£420.00`。
|
||||
@ -168,6 +321,7 @@ echo Yii::$app->formatter->asTime('2014-10-06 21:41:00 JST'); // 21:41:00
|
||||
]
|
||||
```
|
||||
|
||||
<<<<<<< HEAD
|
||||
その他のフォーマッタ <span id="other"></span>
|
||||
--------------------
|
||||
|
||||
@ -176,6 +330,16 @@ echo Yii::$app->formatter->asTime('2014-10-06 21:41:00 JST'); // 21:41:00
|
||||
- [[yii\i18n\Formatter::asRaw()|raw]] - 値はそのまま出力されます。`null` 値が [[nullDisplay]] を使ってフォーマットされる以外は、何の効果もない擬似フォーマッタです。
|
||||
- [[yii\i18n\Formatter::asText()|text]] - 値は HTML エンコードされます。
|
||||
これは [GridView DataColumn](output-data-widgets.md#data-column) で使われるデフォルトの形式です。
|
||||
=======
|
||||
## その他のフォーマット <span id="other"></span>
|
||||
|
||||
日付/時刻と数値のフォーマット以外にも、Yii はよく使われるフォーマットをサポートしています。
|
||||
その中には、次のものが含まれます。
|
||||
|
||||
- [[yii\i18n\Formatter::asRaw()|raw]] - 値はそのまま出力されます。`null` 値が [[nullDisplay]] を使ってフォーマットされる以外は、何の効果もない擬似フォーマッタです。
|
||||
- [[yii\i18n\Formatter::asText()|text]] - 値は HTML エンコードされます。
|
||||
これは [GridView DataColumn](output-data-widgets.md#data-column) で使われるデフォルトのフォーマットです。
|
||||
>>>>>>> master
|
||||
- [[yii\i18n\Formatter::asNtext()|ntext]] - 値は HTML エンコードされ、改行文字が強制改行に変換された平文テキストとしてフォーマットされます。
|
||||
- [[yii\i18n\Formatter::asParagraphs()|paragraphs]] - 値は HTML エンコードされ、`<p>` タグに囲まれた段落としてフォーマットされます。
|
||||
- [[yii\i18n\Formatter::asHtml()|html]] - 値は XSS 攻撃を避けるために [[HtmlPurifier]] を使って浄化されます。
|
||||
@ -185,6 +349,7 @@ echo Yii::$app->formatter->asTime('2014-10-06 21:41:00 JST'); // 21:41:00
|
||||
- [[yii\i18n\Formatter::asUrl()|url]] - 値はハイパーリンクとしてフォーマットされます。
|
||||
- [[yii\i18n\Formatter::asBoolean()|boolean]] - 値は真偽値としてフォーマットされます。
|
||||
デフォルトでは、`true` は `Yes`、`false` は `No` とレンダリングされ、現在のアプリケーションの言語に翻訳されます。
|
||||
<<<<<<< HEAD
|
||||
この振る舞いは [[yii\i18n\Formatter::booleanFormat]] プロパティを構成して調整できます。
|
||||
|
||||
`null` 値 <span id="null-values"></span>
|
||||
@ -194,3 +359,44 @@ PHP において `null` である値に対して、フォーマッタクラス
|
||||
`null` のプレースホルダは、デフォルトでは `(not set)` であり、それが現在のアプリケーションの言語に翻訳されます。
|
||||
[[yii\i18n\Formatter::nullDisplay|nullDisplay]] プロパティを構成して、カスタムのプレースホルダを設定することが出来ます。
|
||||
`null` 値の特別な扱いをしたくない場合は、[[yii\i18n\Formatter::nullDisplay|nullDisplay]] を `null` に設定することが出来ます。
|
||||
=======
|
||||
この動作は [[yii\i18n\Formatter::booleanFormat]] プロパティを構成して調整できます。
|
||||
|
||||
|
||||
## `null` 値 <span id="null-values"></span>
|
||||
|
||||
Null 値は特殊な方法でフォーマットされます。
|
||||
空文字列を表示する代りに、フォーマッタは null 値を事前定義された文字列 (そのデフォルト値は `(not set)` です) に変換し、それを現在のアプリケーションの言語に翻訳します。
|
||||
この文字列は [[yii\i18n\Formatter::nullDisplay|nullDisplay]] プロパティを構成してカスタマイズすることが出来ます。
|
||||
|
||||
## データのフォーマットをローカライズする <span id="localizing-data-format"></span>
|
||||
|
||||
既に述べたように、フォーマッタは現在のアクティブな [[yii\i18n\Formatter::locale|locale]] を使って、ターゲットの国/地域にふさわしい値のフォーマットを決定することが出来ます。
|
||||
例えば、同じ日時の値でも、ロケールによって異なる書式にフォーマットされます。
|
||||
|
||||
```php
|
||||
Yii::$app->formatter->locale = 'en-US';
|
||||
echo Yii::$app->formatter->asDate('2014-01-01'); // 出力: January 1, 2014
|
||||
|
||||
Yii::$app->formatter->locale = 'de-DE';
|
||||
echo Yii::$app->formatter->asDate('2014-01-01'); // 出力: 1. Januar 2014
|
||||
|
||||
Yii::$app->formatter->locale = 'ru-RU';
|
||||
echo Yii::$app->formatter->asDate('2014-01-01'); // 出力: 1 января 2014 г.
|
||||
|
||||
Yii::$app->formatter->locale = 'ja-JP';
|
||||
echo Yii::$app->formatter->asDate('2014-01-01'); // 出力: 2014/01/01
|
||||
```
|
||||
|
||||
デフォルトでは、現在のアクティブな [[yii\i18n\Formatter::locale|locale]] は [[yii\base\Application::language]] の値によって決定されます。
|
||||
これは [[yii\i18n\Formatter::locale]] プロパティを明示的に指定することによってオーバーライドすることが出来ます。
|
||||
|
||||
> Note: Yii のフォーマッタは、[PHP intl extension](http://php.net/manual/ja/book.intl.php) に依存してデータのフォーマットのローカライズをサポートしています。
|
||||
> PHP にコンパイルされた ICU ライブラリのバージョンによってフォーマットの結果が異なる場合がありますので、あなたの全ての環境で、同じ ICU バージョンを使うことが推奨されます。
|
||||
> 詳細については、[PHP 環境を国際化のために設定する](tutorial-i18n.md#setup-environment) を参照してください。
|
||||
>
|
||||
> intl 拡張がインストールされていない場合は、データはローカライズされません。
|
||||
>
|
||||
> 1901年より前、または、2038年より後の日時の値は、たとえ intl 拡張がインストールされていても、32-bit システムではローカライズされないことに注意してください。
|
||||
> これは、この場合、ICU ライブラリが日時の値に対して 32-bit の UNIX タイムスタンプを使用しているのが原因です。
|
||||
>>>>>>> master
|
||||
|
||||
Reference in New Issue
Block a user