Class yii\widgets\DetailView
DetailView displays the detail of a single data $model.
DetailView is best used for displaying a model in a regular format (e.g. each model attribute is displayed as a row in a table.) The model can be either an instance of yii\base\Model or an associative array.
DetailView uses the $attributes property to determines which model attributes should be displayed and how they should be formatted.
A typical usage of DetailView is as follows:
echo DetailView::widget([
    'model' => $model,
    'attributes' => [
        'title',               // title attribute (in plain text)
        'description:html',    // description attribute in HTML
        [                      // the owner name of the model
            'label' => 'Owner',
            'value' => $model->owner->name,
        ],
        'created_at:datetime', // creation date formatted as datetime
    ],
]);
For more details and usage information on DetailView, see the guide article on data widgets.
公共属性
| 属性 | 类型 | 描述 | 被定义在 | 
|---|---|---|---|
| $attributes | array | A list of attributes to be displayed in the detail view. | yii\widgets\DetailView | 
| $autoIdPrefix | string | The prefix to the automatically generated widget IDs. | yii\base\Widget | 
| $behaviors | yii\base\Behavior[] | List of behaviors attached to this component | yii\base\Component | 
| $counter | integer | A counter used to generate $id for widgets. | yii\base\Widget | 
| $formatter | array|yii\i18n\Formatter | The formatter used to format model attribute values into displayable texts. | yii\widgets\DetailView | 
| $id | string | ID of the widget. | yii\base\Widget | 
| $model | array|object | The data model whose details are to be displayed. | yii\widgets\DetailView | 
| $options | array | The HTML attributes for the container tag of this widget. | yii\widgets\DetailView | 
| $stack | yii\base\Widget[] | The widgets that are currently being rendered (not ended). | yii\base\Widget | 
| $template | string|callable | The template used to render a single attribute. | yii\widgets\DetailView | 
| $view | yii\web\View | The view object that can be used to render views or view files. | yii\base\Widget | 
| $viewPath | string | The directory containing the view files for this widget. | yii\base\Widget | 
公共方法
| 方法 | 描述 | 被定义在 | 
|---|---|---|
| __call() | Calls the named method which is not a class method. | yii\base\Component | 
| __clone() | This method is called after the object is created by cloning an existing one. | yii\base\Component | 
| __construct() | Constructor. | yii\base\BaseObject | 
| __get() | Returns the value of a component property. | yii\base\Component | 
| __isset() | Checks if a property is set, i.e. defined and not null. | yii\base\Component | 
| __set() | Sets the value of a component property. | yii\base\Component | 
| __unset() | Sets a component property to be null. | yii\base\Component | 
| afterRun() | This method is invoked right after a widget is executed. | yii\base\Widget | 
| attachBehavior() | Attaches a behavior to this component. | yii\base\Component | 
| attachBehaviors() | Attaches a list of behaviors to the component. | yii\base\Component | 
| beforeRun() | This method is invoked right before the widget is executed. | yii\base\Widget | 
| begin() | Begins a widget. | yii\base\Widget | 
| behaviors() | Returns a list of behaviors that this component should behave as. | yii\base\Component | 
| canGetProperty() | Returns a value indicating whether a property can be read. | yii\base\Component | 
| canSetProperty() | Returns a value indicating whether a property can be set. | yii\base\Component | 
| className() | Returns the fully qualified name of this class. | yii\base\BaseObject | 
| detachBehavior() | Detaches a behavior from the component. | yii\base\Component | 
| detachBehaviors() | Detaches all behaviors from the component. | yii\base\Component | 
| end() | Ends a widget. | yii\base\Widget | 
| ensureBehaviors() | Makes sure that the behaviors declared in behaviors() are attached to this component. | yii\base\Component | 
| getBehavior() | Returns the named behavior object. | yii\base\Component | 
| getBehaviors() | Returns all behaviors attached to this component. | yii\base\Component | 
| getId() | Returns the ID of the widget. | yii\base\Widget | 
| getView() | Returns the view object that can be used to render views or view files. | yii\base\Widget | 
| getViewPath() | Returns the directory containing the view files for this widget. | yii\base\Widget | 
| hasEventHandlers() | Returns a value indicating whether there is any handler attached to the named event. | yii\base\Component | 
| hasMethod() | Returns a value indicating whether a method is defined. | yii\base\Component | 
| hasProperty() | Returns a value indicating whether a property is defined for this component. | yii\base\Component | 
| init() | Initializes the detail view. | yii\widgets\DetailView | 
| off() | Detaches an existing event handler from this component. | yii\base\Component | 
| on() | Attaches an event handler to an event. | yii\base\Component | 
| render() | Renders a view. | yii\base\Widget | 
| renderFile() | Renders a view file. | yii\base\Widget | 
| run() | Renders the detail view. | yii\widgets\DetailView | 
| setId() | Sets the ID of the widget. | yii\base\Widget | 
| setView() | Sets the view object to be used by this widget. | yii\base\Widget | 
| trigger() | Triggers an event. | yii\base\Component | 
| widget() | Creates a widget instance and runs it. | yii\base\Widget | 
受保护的方法
| 方法 | 描述 | 被定义在 | 
|---|---|---|
| normalizeAttributes() | Normalizes the attribute specifications. | yii\widgets\DetailView | 
| renderAttribute() | Renders a single attribute. | yii\widgets\DetailView | 
Events
| 事件 | 类型 | 描述 | 被定义在 | 
|---|---|---|---|
| EVENT_AFTER_RUN | yii\base\WidgetEvent | An event raised right after executing a widget. (自版本 2.0.11 可用) | yii\base\Widget | 
| EVENT_BEFORE_RUN | yii\base\WidgetEvent | An event raised right before executing a widget. (自版本 2.0.11 可用) | yii\base\Widget | 
| EVENT_INIT | yii\base\Event | An event that is triggered when the widget is initialized via init(). (自版本 2.0.11 可用) | yii\base\Widget | 
属性详情
A list of attributes to be displayed in the detail view. Each array element represents the specification for displaying one particular attribute.
An attribute can be specified as a string in the format of attribute, attribute:format or attribute:format:label,
where attribute refers to the attribute name, and format represents the format of the attribute. The format
is passed to the yii\i18n\Formatter::format() method to format an attribute value into a displayable text.
Please refer to yii\i18n\Formatter for the supported types. Both format and label are optional.
They will take default values if absent.
An attribute can also be specified in terms of an array with the following elements:
- attribute: the attribute name. This is required if either- labelor- valueis not specified.
- label: the label associated with the attribute. If this is not specified, it will be generated from the attribute name.
- value: the value to be displayed. If this is not specified, it will be retrieved from $model using the attribute name by calling yii\helpers\ArrayHelper::getValue(). Note that this value will be formatted into a displayable text according to the- formatoption. Since version 2.0.11 it can be defined as closure with the following parameters:- function ($model, $widget)- $modelrefers to displayed model and- $widgetis an instance of- DetailViewwidget.
- format: the type of the value that determines how the value would be formatted into a displayable text. Please refer to yii\i18n\Formatter for supported types and yii\i18n\Formatter::format() on how to specify this value.
- visible: whether the attribute is visible. If set to- false, the attribute will NOT be displayed.
- contentOptions: the HTML attributes to customize value tag. For example:- ['class' => 'bg-red']. Please refer to yii\helpers\BaseHtml::renderTagAttributes() for the supported syntax.
- captionOptions: the HTML attributes to customize label tag. For example:- ['class' => 'bg-red']. Please refer to yii\helpers\BaseHtml::renderTagAttributes() for the supported syntax.
The formatter used to format model attribute values into displayable texts.
This can be either an instance of yii\i18n\Formatter or an configuration array for creating the yii\i18n\Formatter
instance. If this property is not set, the formatter application component will be used.
The data model whose details are to be displayed. This can be a yii\base\Model instance, an associative array, an object that implements yii\base\Arrayable interface or simply an object with defined public accessible non-static properties.
The HTML attributes for the container tag of this widget. The tag option specifies
what container tag should be used. It defaults to table if not set.
参见 yii\helpers\Html::renderTagAttributes() for details on how attributes are being rendered.
The template used to render a single attribute. If a string, the token {label}
and {value} will be replaced with the label and the value of the corresponding attribute.
If a callback (e.g. an anonymous function), the signature must be as follows:
function ($attribute, $index, $widget)
where $attribute refer to the specification of the attribute being rendered, $index is the zero-based
index of the attribute in the $attributes array, and $widget refers to this widget instance.
Since Version 2.0.10, the tokens {captionOptions} and {contentOptions} are available, which will represent
HTML attributes of HTML container elements for the label and value.
方法详情
Initializes the detail view.
This method will initialize required property values.
| public void init() | 
Normalizes the attribute specifications.
| protected void normalizeAttributes() | ||
| throws | yii\base\InvalidConfigException | |
|---|---|---|
Renders a single attribute.
| protected string renderAttribute($attribute, $index) | ||
| $attribute | array | The specification of the attribute to be rendered. | 
| $index | integer | The zero-based index of the attribute in the $attributes array | 
| return | string | The rendering result | 
|---|---|---|
Renders the detail view.
This is the main entry of the whole detail view rendering.
| public void run() |