没有命名空间的类 yii yii\base yii\behaviors yii\caching yii\captcha yii\console yii\console\controllers yii\console\widgets yii\data yii\db yii\db\conditions yii\db\cubrid yii\db\cubrid\conditions yii\db\mssql yii\db\mssql\conditions yii\db\mysql yii\db\oci yii\db\oci\conditions yii\db\pgsql yii\db\sqlite yii\db\sqlite\conditions yii\di yii\filters yii\filters\auth yii\grid yii\helpers yii\i18n yii\log yii\mail yii\mutex yii\rbac yii\rest yii\test yii\validators yii\web yii\widgets

Class yii\widgets\Pjax

继承yii\widgets\Pjax » yii\base\Widget » yii\base\Component » yii\base\BaseObject
实现yii\base\Configurable, yii\base\ViewContextInterface
可用版本自2.0
源码 https://github.com/yiichina/yii2/blob/api/framework/widgets/Pjax.php

Pjax is a widget integrating the pjax jQuery plugin.

Pjax only deals with the content enclosed between its begin() and end() calls, called the body content of the widget. By default, any link click or form submission (for those forms with data-pjax attribute) within the body content will trigger an AJAX request. In responding to the AJAX request, Pjax will send the updated body content (based on the AJAX request) to the client which will replace the old content with the new one. The browser's URL will then be updated using pushState. The whole process requires no reloading of the layout or resources (js, css).

You may configure $linkSelector to specify which links should trigger pjax, and configure $formSelector to specify which form submission may trigger pjax.

You may disable pjax for a specific link inside the container by adding data-pjax="0" attribute to this link.

The following example shows how to use Pjax with the yii\grid\GridView widget so that the grid pagination, sorting and filtering can be done via pjax:

use yii\widgets\Pjax;

Pjax::begin();
echo GridView::widget([...]);
Pjax::end();

公共属性

隐藏继承的属性

属性类型描述被定义在
$autoIdPrefix string The prefix to the automatically generated widget IDs. yii\widgets\Pjax
$behaviors yii\base\Behavior[] List of behaviors attached to this component yii\base\Component
$clientOptions array Additional options to be passed to the pjax JS plugin. yii\widgets\Pjax
$counter integer A counter used to generate $id for widgets. yii\widgets\Pjax
$enablePushState boolean Whether to enable push state. yii\widgets\Pjax
$enableReplaceState boolean Whether to enable replace state. yii\widgets\Pjax
$formSelector string|false The jQuery selector of the forms whose submissions should trigger pjax requests. yii\widgets\Pjax
$id string ID of the widget. yii\base\Widget
$linkSelector string|false The jQuery selector of the links that should trigger pjax requests. yii\widgets\Pjax
$options array The HTML attributes for the widget container tag. yii\widgets\Pjax
$scrollTo boolean|integer How to scroll the page when pjax response is received. yii\widgets\Pjax
$stack yii\base\Widget[] The widgets that are currently being rendered (not ended). yii\base\Widget
$submitEvent string The jQuery event that will trigger form handler. yii\widgets\Pjax
$timeout integer Pjax timeout setting (in milliseconds). yii\widgets\Pjax
$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 object. yii\widgets\Pjax
off() Detaches an existing event handler from this component. yii\base\Component
on() Attaches an event handler to an event. yii\base\Component
registerClientScript() Registers the needed JavaScript. yii\widgets\Pjax
render() Renders a view. yii\base\Widget
renderFile() Renders a view file. yii\base\Widget
run() Executes the widget. yii\widgets\Pjax
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

受保护的方法

隐藏继承的方法

方法描述被定义在
requiresPjax() yii\widgets\Pjax

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

属性详情

$autoIdPrefix 公共 静态 属性

The prefix to the automatically generated widget IDs.

public static string $autoIdPrefix 'p'
$clientOptions 公共 属性

Additional options to be passed to the pjax JS plugin. Please refer to the pjax project page for available options.

public array $clientOptions null
$counter 公共 静态 属性

A counter used to generate $id for widgets.

public static integer $counter 0
$enablePushState 公共 属性

Whether to enable push state.

public boolean $enablePushState true
$enableReplaceState 公共 属性

Whether to enable replace state.

$formSelector 公共 属性

The jQuery selector of the forms whose submissions should trigger pjax requests. If not set, all forms with data-pjax attribute within the enclosed content of Pjax will trigger pjax requests. If set to false, no code will be registered to handle forms. Note that if the response to the pjax request is a full page, a normal request will be sent again.

public string|false $formSelector null
$linkSelector 公共 属性

The jQuery selector of the links that should trigger pjax requests. If not set, all links within the enclosed content of Pjax will trigger pjax requests. If set to false, no code will be registered to handle links. Note that if the response to the pjax request is a full page, a normal request will be sent again.

public string|false $linkSelector null
$options 公共 属性

The HTML attributes for the widget container tag. The following special options are recognized:

  • tag: string, the tag name for the container. Defaults to div This option is available since version 2.0.7. See also yii\helpers\Html::tag().

参见 yii\helpers\Html::renderTagAttributes() for details on how attributes are being rendered.

public array $options = []
$scrollTo 公共 属性

How to scroll the page when pjax response is received. If false, no page scroll will be made. Use a number if you want to scroll to a particular place.

public boolean|integer $scrollTo false
$submitEvent 公共 属性 (自版本 2.0.9 可用)

The jQuery event that will trigger form handler. Defaults to "submit".

public string $submitEvent 'submit'
$timeout 公共 属性

Pjax timeout setting (in milliseconds). This timeout is used when making AJAX requests. Use a bigger number if your server is slow. If the server does not respond within the timeout, a full page load will be triggered.

public integer $timeout 1000

方法详情

init() 公共 方法

Initializes the object.

This method is called at the end of the constructor. The default implementation will trigger an EVENT_INIT event.

public void init()
registerClientScript() 公共 方法

Registers the needed JavaScript.

public void registerClientScript()
requiresPjax() 受保护 方法

protected boolean requiresPjax()
return boolean

Whether the current request requires pjax response from this widget

run() 公共 方法

Executes the widget.

public string run()
return string

The result of widget execution to be outputted.