Yii2 framework backup
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

203 lines
10 KiB

数据格式器
==============
8 years ago
你可以使用 `formatter` [application component](structure-application-components.md) 来格式化数据。
默认 `fomatter` 由 [[yii\i18n\Formatter]] 来实现,这个组件提供了一系列关于日期/时间,数字,货币等的格式化方法。
使用方法如下:
8 years ago
```php
8 years ago
$formatter = \Yii::$app->formatter;
// output: January 1, 2014
echo $formatter->asDate('2014-01-01', 'long');
// output: 12.50%
echo $formatter->asPercent(0.125, 2);
// output: <a href="mailto:cebe@example.com">cebe@example.com</a>
echo $formatter->asEmail('cebe@example.com');
// output: Yes
echo $formatter->asBoolean(true);
// it also handles display of null values:
// output: (Not set)
echo $formatter->asDate(null);
```
8 years ago
我们可以看到,所有的方法都形似 `asXyz()`,这个 `Xzy` 就是所支持的格式化类型。
当然你也可以使用类方法 [[yii\i18n\Formatter::format()|format()]] 来进行格式化,通过这个类方法,你可以更自由地控制格式化的数据,这时候,类方法通常配合 [[yii\grid\GridView]] 或者 [[yii\widgets\DetailView]] 来使用。
8 years ago
举个例子:
8 years ago
```php
8 years ago
// output: January 1, 2014
echo Yii::$app->formatter->format('2014-01-01', 'date');
8 years ago
// 你可以在第二个参数指定一个数组,这个数组提供了一些配置的参数
// 例如这个 2 就是 asPercent() 方法的 $decimals 参数
8 years ago
// output: 12.50%
echo Yii::$app->formatter->format(0.125, ['percent', 2]);
```
> Note: `formatter` 组件用来格式化最终展示给用户的数据.
8 years ago
> 如果你想要将用户的输入进行格式化或者只是将一些别的日期数据进行格式化(这里的格式化说的是机器可读的格式化),不要使用这个组件,
> 而应该使用 [[yii\validators\DateValidator]] 和 [[yii\validators\NumberValidator]] 进行用户输入格式化
> 关于日期格式化,戳这里 [date()](http://php.net/manual/en/function.date.php)
8 years ago
8 years ago
## 配置 Formatter <span id="configuring-formatter"></span>
8 years ago
8 years ago
可以对 `formatter` 组件在 [application configuration](concept-configurations.md#application-configurations) 中进行配置
```php
8 years ago
return [
'components' => [
'formatter' => [
'dateFormat' => 'dd.MM.yyyy',
'decimalSeparator' => ',',
'thousandSeparator' => ' ',
'currencyCode' => 'EUR',
],
],
];
```
8 years ago
可以参考 [[yii\i18n\Formatter]] 的配置
8 years ago
## 格式化时间/日期数据 <span id="date-and-time"></span>
8 years ago
默认支持一下几种格式化格式
8 years ago
- [[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 时间戳 [unix timestamp](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`.
8 years ago
时间/日期数据默认使用 [[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]] 即可。
8 years ago
同时,你还可以配置它使用 [ICU syntax](http://userguide.icu-project.org/formatparse/datetime),同时你也可以配置它使用 [PHP date() 语法](http://php.net/manual/en/function.date.php),只需要加上 `php:` 前缀即可。
8 years ago
```php
8 years ago
// ICU format
echo Yii::$app->formatter->asDate('now', 'yyyy-MM-dd'); // 2014-10-06
8 years ago
// PHP date()-format
echo Yii::$app->formatter->asDate('now', 'php:Y-m-d'); // 2014-10-06
```
8 years ago
不同的国家和地区使用不同的时间格式。 你可以使用短语 (例如 `long`, `short`) 来代替.
`formatter` 组件会根据当前的 [[yii\i18n\Formatter::locale|locale]] 将你的短语转换成合适的格式化输出。
目前支持以下短语 (例子当前的 [[yii\i18n\Formatter::locale|locale]] 为 `en_GB`):
8 years ago
- `short`: will output `06/10/2014` for date and `15:58` for time;
- `medium`: will output `6 Oct 2014` and `15:58:42`;
- `long`: will output `6 October 2014` and `15:58:42 GMT`;
- `full`: will output `Monday, 6 October 2014` and `15:58:42 GMT`.
8 years ago
版本 2.0.7 起,支持格式化日期为不同的系统时钟,具体请查看文档 [[yii\i18n\Formatter::$calendar|$calendar]]-property
8 years ago
8 years ago
### 时区 <span id="time-zones"></span>
8 years ago
8 years ago
格式化时间/日期数据时,你会将他们转换成 [[yii\i18n\Formatter::timeZone|time zone]]
这个时候,默认的时区为 UTC,除非你另外指定 [[yii\i18n\Formatter::defaultTimeZone]]。
8 years ago
8 years ago
下面使用 `Europe/Berlin` 作为默认 [[yii\i18n\Formatter::timeZone|time zone]]
8 years ago
```php
8 years ago
// formatting a UNIX timestamp as a time
echo Yii::$app->formatter->asTime(1412599260); // 14:41:00
8 years ago
// formatting a datetime string (in UTC) as a time
echo Yii::$app->formatter->asTime('2014-10-06 12:41:00'); // 14:41:00
8 years ago
// formatting a datetime string (in CEST) as a time
echo Yii::$app->formatter->asTime('2014-10-06 14:41:00 CEST'); // 14:41:00
```
8 years ago
> 不同的政府和地区政策决定不同的时区, 你在你的时区数据库中可能拿不到最新的数据。
> 这时你可以戳 [ICU manual](http://userguide.icu-project.org/datetime/timezone#TOC-Updating-the-Time-Zone-Data) 来查看如何更新时区。
> 同时,这篇也可以作为参考 [Setting up your PHP environment for internationalization](tutorial-i18n.md#setup-environment)
8 years ago
## 格式化数字 <span id="numbers"></span>
8 years ago
`formatter` 支持如下的方法
8 years ago
- [[yii\i18n\Formatter::asInteger()|integer]]: 这个变量将被格式化为整形 e.g. `42`.
- [[yii\i18n\Formatter::asDecimal()|decimal]]: 这个变量将被格式化为带着逗号的指定精度的浮点型 e.g. `2,542.123` or `2.542,123`.
- [[yii\i18n\Formatter::asPercent()|percent]]: 这个变量将被格式化为百分比 e.g. `42%`.
- [[yii\i18n\Formatter::asScientific()|scientific]]: 这个变量将被格式化为科学计数法 e.g. `4.2E4`.
- [[yii\i18n\Formatter::asCurrency()|currency]]: 这个变量将被格式化为货币 `£420.00`.
使用这个方法前请确认是否已经正确配置 [[yii\i18n\Formatter::locale|locale]]
- [[yii\i18n\Formatter::asSize()|size]]: 这个变量将被格式化为人类可读的字节数 e.g. `410 kibibytes`.
- [[yii\i18n\Formatter::asShortSize()|shortSize]]: 这个变量将被格式化为人类可读的字节数(缩写) [[yii\i18n\Formatter::asSize()|size]], e.g. `410 KiB`.
8 years ago
你可以使用 [[yii\i18n\Formatter::decimalSeparator|decimalSeparator]] 和 [[yii\i18n\Formatter::thousandSeparator|thousandSeparator]] 来进行调整。
他们都会根据当前的 [[yii\i18n\Formatter::locale|locale]] 来进行格式化.
8 years ago
如果你想要进行更高级的配置, 可以使用 [[yii\i18n\Formatter::numberFormatterOptions]] 和 [[yii\i18n\Formatter::numberFormatterTextOptions]],[NumberFormatter class](http://php.net/manual/en/class.numberformatter.php) 来进行格式化。
举个例子,为了调整小数部分的最大值和最小值,你可以配置 [[yii\i18n\Formatter::numberFormatterOptions]] 如下:
```php
8 years ago
'numberFormatterOptions' => [
NumberFormatter::MIN_FRACTION_DIGITS => 0,
NumberFormatter::MAX_FRACTION_DIGITS => 2,
]
```
8 years ago
8 years ago
## 其他的格式化 <span id="other"></span>
8 years ago
8 years ago
除了时间/日期和数字的格式化,Yii 还支持如下的常用格式化
8 years ago
8 years ago
- [[yii\i18n\Formatter::asRaw()|raw]]: 除了 `null` 会被 [[nullDisplay]] 格式化外,原样输出。
- [[yii\i18n\Formatter::asText()|text]]: 编码为 HTML 格式。同时这也是 [GridView DataColumn](output-data-widgets.md#data-column) 默认使用的方法。
- [[yii\i18n\Formatter::asNtext()|ntext]]: 编码为 HTML 格式,换行也将被转换。
- [[yii\i18n\Formatter::asParagraphs()|paragraphs]]: 编码为 HTML 格式,以 `<p>` 标签包裹。
- [[yii\i18n\Formatter::asHtml()|html]]: 这个数值将会被 [[HtmlPurifier]] 来进行过滤来防御 XSS 攻击,你可以添加一些配置例如 `['html', ['Attr.AllowedFrameTargets' => ['_blank']]]`
- [[yii\i18n\Formatter::asEmail()|email]]: 这个数值将被转换为 `mailto` 链接。
- [[yii\i18n\Formatter::asImage()|image]]: 转换为图片标签(`img`)。
- [[yii\i18n\Formatter::asUrl()|url]]: 转换为超链接。
- [[yii\i18n\Formatter::asBoolean()|boolean]]: `true` => `Yes`, `false` => `No`,可以进行另外的配置: [[yii\i18n\Formatter::booleanFormat]] 。
8 years ago
8 years ago
## 空值 <span id="null-values"></span>
8 years ago
8 years ago
空值(`null`)会被特殊格式化. `fommater` 默认会将空值格式化为 `(not set)` 对应的当前的语言.
你可以配置 [[yii\i18n\Formatter::nullDisplay|nullDisplay]] 属性来进行个性化.
8 years ago
8 years ago
## 本地日期格式化 <span id="localizing-data-format"></span>
8 years ago
8 years ago
`formatter` 会使用当前的 [[yii\i18n\Formatter::locale|locale]] 来决定格式化的内容。
对于同样的日期,不同的时区配置会有不同的输出:
8 years ago
```php
Yii::$app->formatter->locale = 'en-US';
echo Yii::$app->formatter->asDate('2014-01-01'); // output: January 1, 2014
Yii::$app->formatter->locale = 'de-DE';
echo Yii::$app->formatter->asDate('2014-01-01'); // output: 1. Januar 2014
Yii::$app->formatter->locale = 'ru-RU';
echo Yii::$app->formatter->asDate('2014-01-01'); // output: 1 января 2014 г.
```
8 years ago
默认配置下,当前 [[yii\i18n\Formatter::locale|locale]] 决定于 [[yii\base\Application::language]].
你可以覆盖 [[yii\i18n\Formatter::locale]] 属性来满足不同的需要。
8 years ago
> Note: Yii formatter 依赖 [PHP intl extension](http://php.net/manual/en/book.intl.php) 来进行本地数据格式化
8 years ago
> 因为不同的 ICU 库可能会导致不同的输出,所以请在你的所有机器上保持 ICU 库的一致性.
> 请戳 [Setting up your PHP environment for internationalization](tutorial-i18n.md#setup-environment).
8 years ago
>
8 years ago
> 如果 `intl` 扩展没有被安装,数据格式化不会考虑本地化.
>
> 在 32 位系统中,1901 年前或者 2038 年后的日期数据将不会被本地化,因为 ICU 使用的是 32 位的 UNIX 时间戳。