Class XmlView
A view class that is used for creating XML responses.
By setting the 'serialize' option in view builder of your controller, you can specify a view variable that should be serialized to XML and used as the response for the request. This allows you to omit views + layouts, if your just need to emit a single view variable as the XML response.
In your controller, you could do the following:
$this->set(['posts' => $posts]);
$this->viewBuilder()->setOption('serialize', true);When the view is rendered, the $posts view variable will be serialized
into XML.
Note The view variable you specify must be compatible with Xml::fromArray().
You can also set 'serialize' as an array. This will create an additional
top level element named <response> containing all the named view variables:
$this->set(compact('posts', 'users', 'stuff'));
$this->viewBuilder()->setOption('serialize', true);The above would generate a XML object that looks like:
<response><posts>...</posts><users>...</users></response>
You can also set 'serialize' to a string or array to serialize only the
specified view variables.
If you don't set the serialize option, you will need a view. You can use extended
views to provide layout like functionality.
Constants
- 
          
          stringNAME_TEMPLATE ¶'templates'Constant for type used for App::path(). 
- 
          
          stringPLUGIN_TEMPLATE_FOLDER ¶'plugin'Constant for folder name containing files for overriding plugin templates. 
- 
          
          stringTYPE_ELEMENT ¶'element'Constant for view file type 'element' 
- 
          
          stringTYPE_LAYOUT ¶'layout'Constant for view file type 'layout' 
- 
          
          stringTYPE_MATCH_ALL ¶'_match_all_'The magic 'match-all' content type that views can use to behave as a fallback during content-type negotiation. 
- 
          
          stringTYPE_TEMPLATE ¶'template'Constant for view file type 'template'. 
Property Summary
- 
        $Blocks public @propertyCake\View\ViewBlock
- 
        $Breadcrumbs public @propertyCake\View\Helper\BreadcrumbsHelper
- 
        $Flash public @propertyCake\View\Helper\FlashHelper
- 
        $Form public @propertyCake\View\Helper\FormHelper
- 
        $Html public @propertyCake\View\Helper\HtmlHelper
- 
        $Number public @propertyCake\View\Helper\NumberHelper
- 
        $Paginator public @propertyCake\View\Helper\PaginatorHelper
- 
        $Text public @propertyCake\View\Helper\TextHelper
- 
        $Time public @propertyCake\View\Helper\TimeHelper
- 
        $Url public @propertyCake\View\Helper\UrlHelper
- 
        $_config protectedarray<string, mixed>Runtime config 
- 
        $_configInitialized protectedboolWhether the config property has already been configured with defaults 
- 
        $_current protectedstringThe currently rendering view file. Used for resolving parent files. 
- 
        $_currentType protectedstringCurrently rendering an element. Used for finding parent fragments for elements. 
- 
        $_defaultConfig protectedarray<string, mixed>Default config options. 
- 
        $_eventClass protectedstringDefault class name for new event objects. 
- 
        $_eventManager protectedCake\Event\EventManagerInterface|nullInstance of the Cake\Event\EventManager this object is using to dispatch inner events. 
- 
        $_ext protectedstringFile extension. Defaults to ".php". 
- 
        $_helpers protectedCake\View\HelperRegistryHelpers collection 
- 
        $_parents protectedarray<string>The names of views and their parents used with View::extend(); 
- 
        $_passedVars protectedarray<string>List of variables to collect from the associated controller. 
- 
        $_paths protectedarray<string>Holds an array of paths. 
- 
        $_pathsForPlugin protectedarray<string[]>Holds an array of plugin paths. 
- 
        $_responseType protected deprecatedstringResponse type. 
- 
        $_stack protectedarray<string>Content stack, used for nested templates that all use View::extend(); 
- 
        $_viewBlockClass protectedstringViewBlock class. 
- 
        $autoLayout protectedboolTurns on or off CakePHP's conventional mode of applying layout files. On by default. Setting to off means that layouts will not be automatically applied to rendered templates. 
- 
        $elementCache protectedstringThe Cache configuration View will use to store cached elements. Changing this will change the default configuration elements are stored under. You can also choose a cache config per element. 
- 
        $helpers protectedarrayAn array of names of built-in helpers to include. 
- 
        $layout protectedstringThe name of the layout file to render the template inside of. The name specified is the filename of the layout in templates/layout/without the .php extension.
- 
        $layoutPath protectedstringXML layouts are located in the layouts/xml/subdirectory
- 
        $name protectedstringName of the controller that created the View if any. 
- 
        $plugin protectedstring|nullThe name of the plugin. 
- 
        $request protectedCake\Http\ServerRequestAn instance of a \Cake\Http\ServerRequest object that contains information about the current request. This object contains all the information about a request and several methods for reading additional information about the request. 
- 
        $response protectedCake\Http\ResponseReference to the Response object 
- 
        $subDir protectedstringXML views are located in the 'xml' subdirectory for controllers' views. 
- 
        $template protectedstringThe name of the template file to render. The name specified is the filename in templates/<SubFolder>/without the .php extension.
- 
        $templatePath protectedstringThe name of the subfolder containing templates for this View. 
- 
        $theme protectedstring|nullThe view theme to use. 
- 
        $viewVars protectedarray<string, mixed>An array of variables 
Method Summary
- 
          __construct() publicConstructor 
- 
          __get() publicMagic accessor for helpers. 
- 
          _checkFilePath() protectedCheck that a view file path does not go outside of the defined template paths. 
- 
          _configDelete() protectedDeletes a single config key. 
- 
          _configRead() protectedReads a config key. 
- 
          _configWrite() protectedWrites a config key. 
- 
          _createCell() protectedCreate and configure the cell instance. 
- 
          _elementCache() protectedGenerate the cache configuration options for an element. 
- 
          _evaluate() protectedSandbox method to evaluate a template / view script in. 
- 
          _getElementFileName() protectedFinds an element filename, returns false on failure. 
- 
          _getLayoutFileName() protectedReturns layout filename for this template as a string. 
- 
          _getSubPaths() protectedFind all sub templates path, based on $basePath If a prefix is defined in the current request, this method will prepend the prefixed template path to the $basePath, cascading up in case the prefix is nested. This is essentially used to find prefixed template paths for elements and layouts. 
- 
          _getTemplateFileName() protectedReturns filename of given action's template file as a string. CamelCased action names will be under_scored by default. This means that you can have LongActionNames that refer to long_action_names.php templates. You can change the inflection rule by overriding _inflectTemplateFileName. 
- 
          _inflectTemplateFileName() protectedChange the name of a view template file into underscored format. 
- 
          _paths() protectedReturn all possible paths to find view files in order 
- 
          _render() protectedRenders and returns output for given template filename with its array of data. Handles parent/extended templates. 
- 
          _renderElement() protectedRenders an element and fires the before and afterRender callbacks for it and writes to the cache if a cache is used 
- 
          _serialize() protectedSerialize view vars. 
- 
          addHelper() protectedAdds a helper from within initialize()method.
- 
          append() publicAppend to an existing or new block. 
- 
          assign() publicSet the content for a block. This will overwrite any existing content. 
- 
          blocks() publicGet the names of all the existing blocks. 
- 
          cache() publicCreate a cached block of view logic. 
- 
          cell() protectedRenders the given cell. 
- 
          configShallow() publicMerge provided config with existing config. Unlike config()which does a recursive merge for nested keys, this method does a simple merge.
- 
          contentType() public staticMime-type this view class renders as. 
- 
          disableAutoLayout() publicTurns off CakePHP's conventional mode of applying layout files. Layouts will not be automatically applied to rendered views. 
- 
          dispatchEvent() publicWrapper for creating and dispatching events. 
- 
          element() publicRenders a piece of PHP with provided parameters and returns HTML, XML, or any other string. 
- 
          elementExists() publicChecks if an element exists 
- 
          enableAutoLayout() publicTurns on or off CakePHP's conventional mode of applying layout files. On by default. Setting to off means that layouts will not be automatically applied to rendered views. 
- 
          end() publicEnd a capturing block. The compliment to View::start() 
- 
          exists() publicCheck if a block exists 
- 
          extend() publicProvides template or element extension/inheritance. Templates can extends a parent template and populate blocks in the parent template. 
- 
          fetch() publicFetch the content for a block. If a block is empty or undefined '' will be returned. 
- 
          get() publicReturns the contents of the given View variable. 
- 
          getConfig() publicGet config value. 
- 
          getConfigOrFail() publicReturns the config for this specific key. 
- 
          getCurrentType() publicRetrieve the current template type 
- 
          getElementPaths() protectedGet an iterator for element paths. 
- 
          getEventManager() publicReturns the Cake\Event\EventManager manager instance for this object. 
- 
          getLayout() publicGet the name of the layout file to render the template inside of. The name specified is the filename of the layout in templates/layout/without the .php extension.
- 
          getLayoutPath() publicGet path for layout files. 
- 
          getLayoutPaths() protectedGet an iterator for layout paths. 
- 
          getName() publicReturns the View's controller name. 
- 
          getPlugin() publicReturns the plugin name. 
- 
          getRequest() publicGets the request instance. 
- 
          getResponse() publicGets the response instance. 
- 
          getSubDir() publicGet sub-directory for this template files. 
- 
          getTemplate() publicGet the name of the template file to render. The name specified is the filename in templates/<SubFolder>/without the .php extension.
- 
          getTemplatePath() publicGet path for templates files. 
- 
          getTheme() publicGet the current view theme. 
- 
          getVars() publicReturns a list of variables available in the current View context 
- 
          helpers() publicGet the helper registry in use by this View class. 
- 
          initialize() publicInitialization hook method. 
- 
          isAutoLayoutEnabled() publicReturns if CakePHP's conventional mode of applying layout files is enabled. Disabled means that layouts will not be automatically applied to rendered views. 
- 
          loadHelper() publicLoads a helper. Delegates to the HelperRegistry::load()to load the helper.
- 
          loadHelpers() publicLoad helpers only if serialization is disabled. 
- 
          log() publicConvenience method to write a message to Log. See Log::write() for more information on writing to logs. 
- 
          pluginSplit() publicSplits a dot syntax plugin name into its plugin and filename. If $name does not have a dot, then index 0 will be null. It checks if the plugin is loaded, else filename will stay unchanged for filenames containing dot 
- 
          prepend() publicPrepend to an existing or new block. 
- 
          render() publicRender view template or return serialized data. 
- 
          renderLayout() publicRenders a layout. Returns output from _render(). 
- 
          reset() publicReset the content for a block. This will overwrite any existing content. 
- 
          set() publicSaves a variable or an associative array of variables for use inside a template. 
- 
          setConfig() publicSets the config. 
- 
          setContentType() protectedSet the response content-type based on the view's contentType() 
- 
          setElementCache() publicSet The cache configuration View will use to store cached elements 
- 
          setEventManager() publicReturns the Cake\Event\EventManagerInterface instance for this object. 
- 
          setLayout() publicSet the name of the layout file to render the template inside of. The name specified is the filename of the layout in templates/layout/without the .php extension.
- 
          setLayoutPath() publicSet path for layout files. 
- 
          setPlugin() publicSets the plugin name. 
- 
          setRequest() publicSets the request objects and configures a number of controller properties based on the contents of the request. The properties that get set are: 
- 
          setResponse() publicSets the response instance. 
- 
          setSubDir() publicSet sub-directory for this template files. 
- 
          setTemplate() publicSet the name of the template file to render. The name specified is the filename in templates/<SubFolder>/without the .php extension.
- 
          setTemplatePath() publicSet path for templates files. 
- 
          setTheme() publicSet the view theme to use. 
- 
          start() publicStart capturing output for a 'block' 
Method Detail
__construct() ¶ public
__construct(Cake\Http\ServerRequest|null $request = null, Cake\Http\Response|null $response = null, Cake\Event\EventManager|null $eventManager = null, array<string, mixed> $viewOptions = [])Constructor
Parameters
- 
                Cake\Http\ServerRequest|null$request optional
- Request instance. 
- 
                Cake\Http\Response|null$response optional
- Response instance. 
- 
                Cake\Event\EventManager|null$eventManager optional
- Event manager instance. 
- 
                array<string, mixed>$viewOptions optional
- View options. See {@link View::$_passedVars} for list of options which get set as class properties. 
__get() ¶ public
__get(string $name): Cake\View\Helper|nullMagic accessor for helpers.
Parameters
- 
                string$name
- Name of the attribute to get. 
Returns
Cake\View\Helper|null_checkFilePath() ¶ protected
_checkFilePath(string $file, string $path): stringCheck that a view file path does not go outside of the defined template paths.
Only paths that contain .. will be checked, as they are the ones most likely to
have the ability to resolve to files outside of the template paths.
Parameters
- 
                string$file
- The path to the template file. 
- 
                string$path
- Base path that $file should be inside of. 
Returns
stringThrows
InvalidArgumentException_configDelete() ¶ protected
_configDelete(string $key): voidDeletes a single config key.
Parameters
- 
                string$key
- Key to delete. 
Returns
voidThrows
Cake\Core\Exception\CakeExceptionif attempting to clobber existing config
_configRead() ¶ protected
_configRead(string|null $key): mixedReads a config key.
Parameters
- 
                string|null$key
- Key to read. 
Returns
mixed_configWrite() ¶ protected
_configWrite(array<string, mixed>|string $key, mixed $value, string|bool $merge = false): voidWrites a config key.
Parameters
- 
                array<string, mixed>|string$key
- Key to write to. 
- 
                mixed$value
- Value to write. 
- 
                string|bool$merge optional
- True to merge recursively, 'shallow' for simple merge, false to overwrite, defaults to false. 
Returns
voidThrows
Cake\Core\Exception\CakeExceptionif attempting to clobber existing config
_createCell() ¶ protected
_createCell(string $className, string $action, string|null $plugin, array<string, mixed> $options): Cake\View\CellCreate and configure the cell instance.
Parameters
- 
                string$className
- The cell classname. 
- 
                string$action
- The action name. 
- 
                string|null$plugin
- The plugin name. 
- 
                array<string, mixed>$options
- The constructor options for the cell. 
Returns
Cake\View\Cell_elementCache() ¶ protected
_elementCache(string $name, array $data, array<string, mixed> $options): arrayGenerate the cache configuration options for an element.
Parameters
- 
                string$name
- Element name 
- 
                array$data
- Data 
- 
                array<string, mixed>$options
- Element options 
Returns
array_evaluate() ¶ protected
_evaluate(string $templateFile, array $dataForView): stringSandbox method to evaluate a template / view script in.
Parameters
- 
                string$templateFile
- Filename of the template. 
- 
                array$dataForView
- Data to include in rendered view. 
Returns
string_getElementFileName() ¶ protected
_getElementFileName(string $name, bool $pluginCheck = true): string|falseFinds an element filename, returns false on failure.
Parameters
- 
                string$name
- The name of the element to find. 
- 
                bool$pluginCheck optional
- if false will ignore the request's plugin if parsed plugin is not loaded
 
Returns
string|false_getLayoutFileName() ¶ protected
_getLayoutFileName(string|null $name = null): stringReturns layout filename for this template as a string.
Parameters
- 
                string|null$name optional
- The name of the layout to find. 
Returns
stringThrows
Cake\View\Exception\MissingLayoutExceptionwhen a layout cannot be located
RuntimeException_getSubPaths() ¶ protected
_getSubPaths(string $basePath): array<string>Find all sub templates path, based on $basePath If a prefix is defined in the current request, this method will prepend the prefixed template path to the $basePath, cascading up in case the prefix is nested. This is essentially used to find prefixed template paths for elements and layouts.
Parameters
- 
                string$basePath
- Base path on which to get the prefixed one. 
Returns
array<string>_getTemplateFileName() ¶ protected
_getTemplateFileName(string|null $name = null): stringReturns filename of given action's template file as a string. CamelCased action names will be under_scored by default. This means that you can have LongActionNames that refer to long_action_names.php templates. You can change the inflection rule by overriding _inflectTemplateFileName.
Parameters
- 
                string|null$name optional
- Controller action to find template filename for 
Returns
stringThrows
Cake\View\Exception\MissingTemplateExceptionwhen a template file could not be found.
RuntimeExceptionWhen template name not provided.
_inflectTemplateFileName() ¶ protected
_inflectTemplateFileName(string $name): stringChange the name of a view template file into underscored format.
Parameters
- 
                string$name
- Name of file which should be inflected. 
Returns
string_paths() ¶ protected
_paths(string|null $plugin = null, bool $cached = true): array<string>Return all possible paths to find view files in order
Parameters
- 
                string|null$plugin optional
- Optional plugin name to scan for view files. 
- 
                bool$cached optional
- Set to false to force a refresh of view paths. Default true. 
Returns
array<string>_render() ¶ protected
_render(string $templateFile, array $data = []): stringRenders and returns output for given template filename with its array of data. Handles parent/extended templates.
Parameters
- 
                string$templateFile
- Filename of the template 
- 
                array$data optional
- Data to include in rendered view. If empty the current View::$viewVars will be used. 
Returns
stringThrows
LogicExceptionWhen a block is left open.
_renderElement() ¶ protected
_renderElement(string $file, array $data, array<string, mixed> $options): stringRenders an element and fires the before and afterRender callbacks for it and writes to the cache if a cache is used
Parameters
- 
                string$file
- Element file path 
- 
                array$data
- Data to render 
- 
                array<string, mixed>$options
- Element options 
Returns
string_serialize() ¶ protected
_serialize(array|string $serialize): stringSerialize view vars.
Parameters
- 
                array|string$serialize
Returns
stringaddHelper() ¶ protected
addHelper(string $helper, array<string, mixed> $config = []): voidAdds a helper from within initialize() method.
Parameters
- 
                string$helper
- Helper. 
- 
                array<string, mixed>$config optional
- Config. 
Returns
voidappend() ¶ public
append(string $name, mixed $value = null): $thisAppend to an existing or new block.
Appending to a new block will create the block.
Parameters
- 
                string$name
- Name of the block 
- 
                mixed$value optional
- The content for the block. Value will be type cast to string. 
Returns
$thisSee Also
assign() ¶ public
assign(string $name, mixed $value): $thisSet the content for a block. This will overwrite any existing content.
Parameters
- 
                string$name
- Name of the block 
- 
                mixed$value
- The content for the block. Value will be type cast to string. 
Returns
$thisSee Also
blocks() ¶ public
blocks(): array<string>Get the names of all the existing blocks.
Returns
array<string>See Also
cache() ¶ public
cache(callable $block, array<string, mixed> $options = []): stringCreate a cached block of view logic.
This allows you to cache a block of view output into the cache
defined in elementCache.
This method will attempt to read the cache first. If the cache is empty, the $block will be run and the output stored.
Parameters
- 
                callable$block
- The block of code that you want to cache the output of. 
- 
                array<string, mixed>$options optional
- The options defining the cache key etc. 
Returns
stringThrows
RuntimeExceptionWhen $options is lacking a 'key' option.
cell() ¶ protected
cell(string $cell, array $data = [], array<string, mixed> $options = []): Cake\View\CellRenders the given cell.
Example:
// Taxonomy\View\Cell\TagCloudCell::smallList()
$cell = $this->cell('Taxonomy.TagCloud::smallList', ['limit' => 10]);
// App\View\Cell\TagCloudCell::smallList()
$cell = $this->cell('TagCloud::smallList', ['limit' => 10]);The display action will be used by default when no action is provided:
// Taxonomy\View\Cell\TagCloudCell::display()
$cell = $this->cell('Taxonomy.TagCloud');Cells are not rendered until they are echoed.
Parameters
- 
                string$cell
- You must indicate cell name, and optionally a cell action. e.g.: - TagCloud::smallListwill invoke- View\Cell\TagCloudCell::smallList(),- displayaction will be invoked by default when none is provided.
- 
                array$data optional
- Additional arguments for cell method. e.g.: - cell('TagCloud::smallList', ['a1' => 'v1', 'a2' => 'v2'])maps to- View\Cell\TagCloud::smallList(v1, v2)
- 
                array<string, mixed>$options optional
- Options for Cell's constructor 
Returns
Cake\View\CellThrows
Cake\View\Exception\MissingCellExceptionIf Cell class was not found.
configShallow() ¶ public
configShallow(array<string, mixed>|string $key, mixed|null $value = null): $thisMerge provided config with existing config. Unlike config() which does
a recursive merge for nested keys, this method does a simple merge.
Setting a specific value:
$this->configShallow('key', $value);Setting a nested value:
$this->configShallow('some.nested.key', $value);Updating multiple config settings at the same time:
$this->configShallow(['one' => 'value', 'another' => 'value']);Parameters
- 
                array<string, mixed>|string$key
- The key to set, or a complete array of configs. 
- 
                mixed|null$value optional
- The value to set. 
Returns
$thiscontentType() ¶ public static
contentType(): stringMime-type this view class renders as.
Returns
stringdisableAutoLayout() ¶ public
disableAutoLayout(): $thisTurns off CakePHP's conventional mode of applying layout files. Layouts will not be automatically applied to rendered views.
Returns
$thisdispatchEvent() ¶ public
dispatchEvent(string $name, array|null $data = null, object|null $subject = null): Cake\Event\EventInterfaceWrapper for creating and dispatching events.
Returns a dispatched event.
Parameters
- 
                string$name
- Name of the event. 
- 
                array|null$data optional
- Any value you wish to be transported with this event to it can be read by listeners. 
- 
                object|null$subject optional
- The object that this event applies to ($this by default). 
Returns
Cake\Event\EventInterfaceelement() ¶ public
element(string $name, array $data = [], array<string, mixed> $options = []): stringRenders a piece of PHP with provided parameters and returns HTML, XML, or any other string.
This realizes the concept of Elements, (or "partial layouts") and the $params array is used to send
data to be used in the element. Elements can be cached improving performance by using the cache option.
Parameters
- 
                string$name
- Name of template file in the - templates/element/folder, or- MyPlugin.templateto use the template element from MyPlugin. If the element is not found in the plugin, the normal view path cascade will be searched.
- 
                array$data optional
- Array of data to be made available to the rendered view (i.e. the Element) 
- 
                array<string, mixed>$options optional
- Array of options. Possible keys are: 
Returns
stringThrows
Cake\View\Exception\MissingElementExceptionWhen an element is missing and `ignoreMissing` is false.
elementExists() ¶ public
elementExists(string $name): boolChecks if an element exists
Parameters
- 
                string$name
- Name of template file in the - templates/element/folder, or- MyPlugin.templateto check the template element from MyPlugin. If the element is not found in the plugin, the normal view path cascade will be searched.
Returns
boolenableAutoLayout() ¶ public
enableAutoLayout(bool $enable = true): $thisTurns on or off CakePHP's conventional mode of applying layout files. On by default. Setting to off means that layouts will not be automatically applied to rendered views.
Parameters
- 
                bool$enable optional
- Boolean to turn on/off. 
Returns
$thisend() ¶ public
end(): $thisEnd a capturing block. The compliment to View::start()
Returns
$thisSee Also
exists() ¶ public
exists(string $name): boolCheck if a block exists
Parameters
- 
                string$name
- Name of the block 
Returns
boolextend() ¶ public
extend(string $name): $thisProvides template or element extension/inheritance. Templates can extends a parent template and populate blocks in the parent template.
Parameters
- 
                string$name
- The template or element to 'extend' the current one with. 
Returns
$thisThrows
LogicExceptionwhen you extend a template with itself or make extend loops.
LogicExceptionwhen you extend an element which doesn't exist
fetch() ¶ public
fetch(string $name, string $default = ''): stringFetch the content for a block. If a block is empty or undefined '' will be returned.
Parameters
- 
                string$name
- Name of the block 
- 
                string$default optional
- Default text 
Returns
stringSee Also
get() ¶ public
get(string $var, mixed $default = null): mixedReturns the contents of the given View variable.
Parameters
- 
                string$var
- The view var you want the contents of. 
- 
                mixed$default optional
- The default/fallback content of $var. 
Returns
mixedgetConfig() ¶ public
getConfig(string|null $key = null, mixed $default = null): mixedGet config value.
Currently if config is not set it fallbacks to checking corresponding view var with underscore prefix. Using underscore prefixed special view vars is deprecated and this fallback will be removed in CakePHP 4.1.0.
Parameters
- 
                string|null$key optional
- The key to get or null for the whole config. 
- 
                mixed$default optional
- The return value when the key does not exist. 
Returns
mixedgetConfigOrFail() ¶ public
getConfigOrFail(string $key): mixedReturns the config for this specific key.
The config value for this key must exist, it can never be null.
Parameters
- 
                string$key
- The key to get. 
Returns
mixedThrows
InvalidArgumentExceptiongetCurrentType() ¶ public
getCurrentType(): stringRetrieve the current template type
Returns
stringgetElementPaths() ¶ protected
getElementPaths(string|null $plugin): GeneratorGet an iterator for element paths.
Parameters
- 
                string|null$plugin
- The plugin to fetch paths for. 
Returns
GeneratorgetEventManager() ¶ public
getEventManager(): Cake\Event\EventManagerInterfaceReturns the Cake\Event\EventManager manager instance for this object.
You can use this instance to register any new listeners or callbacks to the object events, or create your own events and trigger them at will.
Returns
Cake\Event\EventManagerInterfacegetLayout() ¶ public
getLayout(): stringGet the name of the layout file to render the template inside of.
The name specified is the filename of the layout in templates/layout/
without the .php extension.
Returns
stringgetLayoutPaths() ¶ protected
getLayoutPaths(string|null $plugin): GeneratorGet an iterator for layout paths.
Parameters
- 
                string|null$plugin
- The plugin to fetch paths for. 
Returns
GeneratorgetRequest() ¶ public
getRequest(): Cake\Http\ServerRequestGets the request instance.
Returns
Cake\Http\ServerRequestgetResponse() ¶ public
getResponse(): Cake\Http\ResponseGets the response instance.
Returns
Cake\Http\ResponsegetSubDir() ¶ public
getSubDir(): stringGet sub-directory for this template files.
Returns
stringSee Also
getTemplate() ¶ public
getTemplate(): stringGet the name of the template file to render. The name specified is the
filename in templates/<SubFolder>/ without the .php extension.
Returns
stringgetVars() ¶ public
getVars(): array<string>Returns a list of variables available in the current View context
Returns
array<string>helpers() ¶ public
helpers(): Cake\View\HelperRegistryGet the helper registry in use by this View class.
Returns
Cake\View\HelperRegistryinitialize() ¶ public
initialize(): voidInitialization hook method.
Properties like $helpers etc. cannot be initialized statically in your custom view class as they are overwritten by values from controller in constructor. So this method allows you to manipulate them as required after view instance is constructed.
Returns
voidisAutoLayoutEnabled() ¶ public
isAutoLayoutEnabled(): boolReturns if CakePHP's conventional mode of applying layout files is enabled. Disabled means that layouts will not be automatically applied to rendered views.
Returns
boolloadHelper() ¶ public
loadHelper(string $name, array<string, mixed> $config = []): Cake\View\HelperLoads a helper. Delegates to the HelperRegistry::load() to load the helper.
You should use addHelper() instead of this method from the initialize() hook of AppView or other custom View classes.
Parameters
- 
                string$name
- Name of the helper to load. 
- 
                array<string, mixed>$config optional
- Settings for the helper 
Returns
Cake\View\HelperSee Also
loadHelpers() ¶ public
loadHelpers(): $thisLoad helpers only if serialization is disabled.
Returns
$thislog() ¶ public
log(string $message, string|int $level = LogLevel::ERROR, array|string $context = []): boolConvenience method to write a message to Log. See Log::write() for more information on writing to logs.
Parameters
- 
                string$message
- Log message. 
- 
                string|int$level optional
- Error level. 
- 
                array|string$context optional
- Additional log data relevant to this message. 
Returns
boolpluginSplit() ¶ public
pluginSplit(string $name, bool $fallback = true): arraySplits a dot syntax plugin name into its plugin and filename. If $name does not have a dot, then index 0 will be null. It checks if the plugin is loaded, else filename will stay unchanged for filenames containing dot
Parameters
- 
                string$name
- The name you want to plugin split. 
- 
                bool$fallback optional
- If true uses the plugin set in the current Request when parsed plugin is not loaded 
Returns
arrayprepend() ¶ public
prepend(string $name, mixed $value): $thisPrepend to an existing or new block.
Prepending to a new block will create the block.
Parameters
- 
                string$name
- Name of the block 
- 
                mixed$value
- The content for the block. Value will be type cast to string. 
Returns
$thisSee Also
render() ¶ public
render(string|null $template = null, string|false|null $layout = null): stringRender view template or return serialized data.
Render triggers helper callbacks, which are fired before and after the template are rendered, as well as before and after the layout. The helper callbacks are called:
- beforeRender
- afterRender
- beforeLayout
- afterLayout
If View::$autoLayout is set to false, the template will be returned bare.
Template and layout names can point to plugin templates or layouts. Using the Plugin.template syntax
a plugin template/layout/ can be used instead of the app ones. If the chosen plugin is not found
the template will be located along the regular view path cascade.
Parameters
- 
                string|null$template optional
- The template being rendered. 
- 
                string|false|null$layout optional
- The layout being rendered. 
Returns
stringThrows
Cake\View\Exception\SerializationFailureExceptionWhen serialization fails.
renderLayout() ¶ public
renderLayout(string $content, string|null $layout = null): stringRenders a layout. Returns output from _render().
Several variables are created for use in layout.
Parameters
- 
                string$content
- Content to render in a template, wrapped by the surrounding layout. 
- 
                string|null$layout optional
- Layout name 
Returns
stringThrows
Cake\Core\Exception\CakeExceptionif there is an error in the view.
reset() ¶ public
reset(string $name): $thisReset the content for a block. This will overwrite any existing content.
Parameters
- 
                string$name
- Name of the block 
Returns
$thisSee Also
set() ¶ public
set(array|string $name, mixed $value = null): $thisSaves a variable or an associative array of variables for use inside a template.
Parameters
- 
                array|string$name
- A string or an array of data. 
- 
                mixed$value optional
- Value in case $name is a string (which then works as the key). Unused if $name is an associative array, otherwise serves as the values to $name's keys. 
Returns
$thisThrows
RuntimeExceptionIf the array combine operation failed.
setConfig() ¶ public
setConfig(array<string, mixed>|string $key, mixed|null $value = null, bool $merge = true): $thisSets the config.
Usage
Setting a specific value:
$this->setConfig('key', $value);Setting a nested value:
$this->setConfig('some.nested.key', $value);Updating multiple config settings at the same time:
$this->setConfig(['one' => 'value', 'another' => 'value']);Parameters
- 
                array<string, mixed>|string$key
- The key to set, or a complete array of configs. 
- 
                mixed|null$value optional
- The value to set. 
- 
                bool$merge optional
- Whether to recursively merge or overwrite existing config, defaults to true. 
Returns
$thisThrows
Cake\Core\Exception\CakeExceptionWhen trying to set a key that is invalid.
setContentType() ¶ protected
setContentType(): voidSet the response content-type based on the view's contentType()
Returns
voidsetElementCache() ¶ public
setElementCache(string $elementCache): $thisSet The cache configuration View will use to store cached elements
Parameters
- 
                string$elementCache
- Cache config name. 
Returns
$thisSee Also
setEventManager() ¶ public
setEventManager(Cake\Event\EventManagerInterface $eventManager): $thisReturns the Cake\Event\EventManagerInterface instance for this object.
You can use this instance to register any new listeners or callbacks to the object events, or create your own events and trigger them at will.
Parameters
- 
                Cake\Event\EventManagerInterface$eventManager
- the eventManager to set 
Returns
$thissetLayout() ¶ public
setLayout(string $name): $thisSet the name of the layout file to render the template inside of.
The name specified is the filename of the layout in templates/layout/
without the .php extension.
Parameters
- 
                string$name
- Layout file name to set. 
Returns
$thissetLayoutPath() ¶ public
setLayoutPath(string $path): $thisSet path for layout files.
Parameters
- 
                string$path
- Path for layout files. 
Returns
$thissetPlugin() ¶ public
setPlugin(string|null $name): $thisSets the plugin name.
Parameters
- 
                string|null$name
- Plugin name. 
Returns
$thissetRequest() ¶ public
setRequest(Cake\Http\ServerRequest $request): $thisSets the request objects and configures a number of controller properties based on the contents of the request. The properties that get set are:
- $this->request - To the $request parameter
- $this->plugin - To the value returned by $request->getParam('plugin')
Parameters
- 
                Cake\Http\ServerRequest$request
- Request instance. 
Returns
$thissetResponse() ¶ public
setResponse(Cake\Http\Response $response): $thisSets the response instance.
Parameters
- 
                Cake\Http\Response$response
- Response instance. 
Returns
$thissetSubDir() ¶ public
setSubDir(string $subDir): $thisSet sub-directory for this template files.
Parameters
- 
                string$subDir
- Sub-directory name. 
Returns
$thisSee Also
setTemplate() ¶ public
setTemplate(string $name): $thisSet the name of the template file to render. The name specified is the
filename in templates/<SubFolder>/ without the .php extension.
Parameters
- 
                string$name
- Template file name to set. 
Returns
$thissetTemplatePath() ¶ public
setTemplatePath(string $path): $thisSet path for templates files.
Parameters
- 
                string$path
- Path for template files. 
Returns
$thissetTheme() ¶ public
setTheme(string|null $theme): $thisSet the view theme to use.
Parameters
- 
                string|null$theme
- Theme name. 
Returns
$thisstart() ¶ public
start(string $name): $thisStart capturing output for a 'block'
You can use start on a block multiple times to append or prepend content in a capture mode.
// Append content to an existing block.
$this->start('content');
echo $this->fetch('content');
echo 'Some new content';
$this->end();
// Prepend content to an existing block
$this->start('content');
echo 'Some new content';
echo $this->fetch('content');
$this->end();Parameters
- 
                string$name
- The name of the block to capture for. 
Returns
$thisSee Also
Property Detail
$_configInitialized ¶ protected
Whether the config property has already been configured with defaults
Type
bool$_current ¶ protected
The currently rendering view file. Used for resolving parent files.
Type
string$_currentType ¶ protected
Currently rendering an element. Used for finding parent fragments for elements.
Type
string$_defaultConfig ¶ protected
Default config options.
Use ViewBuilder::setOption()/setOptions() in your controller to set these options.
- serialize: Option to convert a set of view variables into a serialized response. Its value can be a string for single variable name or array for multiple names. If true all view variables will be serialized. If null or false normal view template will be rendered.
- xmlOptions: Option to allow setting an array of custom options for Xml::fromArray(). For e.g. 'format' as 'attributes' instead of 'tags'.
- rootNode: Root node name. Defaults to "response".
Type
array<string, mixed>$_eventManager ¶ protected
Instance of the Cake\Event\EventManager this object is using to dispatch inner events.
Type
Cake\Event\EventManagerInterface|null$_parents ¶ protected
The names of views and their parents used with View::extend();
Type
array<string>$_passedVars ¶ protected
List of variables to collect from the associated controller.
Type
array<string>$_stack ¶ protected
Content stack, used for nested templates that all use View::extend();
Type
array<string>$autoLayout ¶ protected
Turns on or off CakePHP's conventional mode of applying layout files. On by default. Setting to off means that layouts will not be automatically applied to rendered templates.
Type
bool$elementCache ¶ protected
The Cache configuration View will use to store cached elements. Changing this will change the default configuration elements are stored under. You can also choose a cache config per element.
Type
string$layout ¶ protected
The name of the layout file to render the template inside of. The name specified
is the filename of the layout in templates/layout/ without the .php
extension.
Type
string$request ¶ protected
An instance of a \Cake\Http\ServerRequest object that contains information about the current request. This object contains all the information about a request and several methods for reading additional information about the request.
Type
Cake\Http\ServerRequest$subDir ¶ protected
XML views are located in the 'xml' subdirectory for controllers' views.
Type
string$template ¶ protected
The name of the template file to render. The name specified
is the filename in templates/<SubFolder>/ without the .php extension.
Type
string