Class UrlHelper
UrlHelper class for generating URLs.
- Cake\View\Helper implements Cake\Event\EventListenerInterface uses Cake\Core\InstanceConfigTrait
- Cake\View\Helper\UrlHelper
Inherited Properties
-
_View
,_defaultConfig
,_helperMap
,fieldset
,helpers
,plugin
,request
,tags
,theme
_config
,_configInitialized
Method Summary
- _encodeUrl() protectedEncodes a URL for use in HTML attributes.
- _inflectThemeName() protectedInflect the theme name to its underscored version.
- assetTimestamp() public
Adds a timestamp to a file based resource based on the value of
Asset.timestamp
in Configure. If Asset.timestamp is true and debug is true, or Asset.timestamp === 'force' a timestamp will be added. - assetUrl() publicGenerates URL for given asset file.
- build() publicReturns a URL based on provided parameters.
- css() publicGenerates URL for given CSS file.
- image() publicGenerates URL for given image file.
- implementedEvents() publicEvent listeners.
- script() publicGenerates URL for given javascript file.
- webroot() publicChecks if a file exists when theme is used, if no file is found default location is returned
Method Detail
_encodeUrl()source protected
_encodeUrl( string $url )
Encodes a URL for use in HTML attributes.
Parameters
- string
$url
- The URL to encode.
Returns
stringThe URL encoded for both URL & HTML contexts.
_inflectThemeName()source protected
_inflectThemeName( string $name )
Inflect the theme name to its underscored version.
Parameters
- string
$name
- Name of the theme which should be inflected.
Returns
stringInflected name of the theme
assetTimestamp()source public
assetTimestamp( string $path , boolean|string $timestamp = null )
Adds a timestamp to a file based resource based on the value of Asset.timestamp
in Configure. If Asset.timestamp is true and debug is true, or Asset.timestamp === 'force' a timestamp will be added.
Parameters
- string
$path
- The file path to timestamp, the path must be inside WWW_ROOT
- boolean|string
$timestamp
optional null - If set will overrule the value of
Asset.timestamp
in Configure.
Returns
stringPath with a timestamp added, or not.
assetUrl()source public
assetUrl( string|array $path , array $options = [] )
Generates URL for given asset file.
Depending on options passed provides full URL with domain name. Also calls Helper::assetTimestamp()
to add timestamp to local files.
Parameters
- string|array
$path
- Path string or URL array
- array
$options
optional [] Options array. Possible keys:
fullBase
Return full URL with domain namepathPrefix
Path prefix for relative URLsext
Asset extension to appendplugin
False value will prevent parsing path as a plugintimestamp
Overrides the value ofAsset.timestamp
in Configure. Set to false to skip timestamp generation. Set to true to apply timestamps when debug is true. Set to 'force' to always enable timestamping regardless of debug value.
Returns
stringGenerated URL
build()source public
build( string|array|null $url = null , array|boolean $options = false )
Returns a URL based on provided parameters.
Options:
-
escape
: If false, the URL will be returned unescaped, do only use if it is manually escaped afterwards before being displayed. -
fullBase
: If true, the full base URL will be prepended to the result
Parameters
- string|array|null
$url
optional null Either a relative string URL like
/products/view/23
or an array of URL parameters. Using an array for URLs will allow you to leverage the reverse routing features of CakePHP.- array|boolean
$options
optional false - Array of options; bool
full
for BC reasons.
Returns
stringFull translated URL with base path.
css()source public
css( string|array $path , array $options = [] )
Generates URL for given CSS file.
Depending on options passed provides full URL with domain name. Also calls Helper::assetTimestamp()
to add timestamp to local files.
Parameters
- string|array
$path
- Path string or URL array
- array
$options
optional [] Options array. Possible keys:
fullBase
Return full URL with domain namepathPrefix
Path prefix for relative URLsext
Asset extension to appendplugin
False value will prevent parsing path as a plugintimestamp
Overrides the value ofAsset.timestamp
in Configure. Set to false to skip timestamp generation. Set to true to apply timestamps when debug is true. Set to 'force' to always enable timestamping regardless of debug value.
Returns
stringGenerated URL
image()source public
image( string|array $path , array $options = [] )
Generates URL for given image file.
Depending on options passed provides full URL with domain name. Also calls Helper::assetTimestamp()
to add timestamp to local files.
Parameters
- string|array
$path
- Path string or URL array
- array
$options
optional [] Options array. Possible keys:
fullBase
Return full URL with domain namepathPrefix
Path prefix for relative URLsplugin
False value will prevent parsing path as a plugintimestamp
Overrides the value ofAsset.timestamp
in Configure. Set to false to skip timestamp generation. Set to true to apply timestamps when debug is true. Set to 'force' to always enable timestamping regardless of debug value.
Returns
stringGenerated URL
implementedEvents()source public
implementedEvents( )
Event listeners.
Returns
arrayOverrides
Cake\View\Helper::implementedEvents()
script()source public
script( string|array $path , array $options = [] )
Generates URL for given javascript file.
Depending on options passed provides full URL with domain name. Also calls Helper::assetTimestamp()
to add timestamp to local files.
Parameters
- string|array
$path
- Path string or URL array
- array
$options
optional [] Options array. Possible keys:
fullBase
Return full URL with domain namepathPrefix
Path prefix for relative URLsext
Asset extension to appendplugin
False value will prevent parsing path as a plugintimestamp
Overrides the value ofAsset.timestamp
in Configure. Set to false to skip timestamp generation. Set to true to apply timestamps when debug is true. Set to 'force' to always enable timestamping regardless of debug value.
Returns
stringGenerated URL
webroot()source public
webroot( string $file )
Checks if a file exists when theme is used, if no file is found default location is returned
Parameters
- string
$file
- The file to create a webroot path to.
Returns
stringWeb accessible path to file.
Methods inherited from Cake\View\Helper
__call()source public
__call( string $method , array $params )
Provide non fatal errors on missing method calls.
Parameters
- string
$method
- Method to invoke
- array
$params
- Array of params for the method.
__construct()source public
__construct( Cake\View\View $View , array $config = [] )
Default Constructor
Parameters
-
Cake\View\View
$View
- The View this helper is being attached to.
- array
$config
optional [] - Configuration settings for the helper.
__debugInfo()source public
__debugInfo( )
Returns an array that can be used to describe the internal state of this object.
Returns
array__get()source public
__get( string $name )
Lazy loads helpers.
Parameters
- string
$name
- Name of the property being accessed.
Returns
Cake\View\Helper
|nullHelper instance if helper with provided name exists
_confirm()source protected
_confirm( string $message , string $okCode , string $cancelCode = '' , array $options = [] )
Returns a string to be used as onclick handler for confirm dialogs.
Parameters
- string
$message
- Message to be displayed
- string
$okCode
- Code to be executed after user chose 'OK'
- string
$cancelCode
optional '' - Code to be executed after user chose 'Cancel'
- array
$options
optional [] - Array of options
Returns
stringonclick JS code
addClass()source public
addClass( array $options = [] , string|null $class = null , string $key = 'class' )
Adds the given class to the element options
Parameters
- array
$options
optional [] - Array options/attributes to add a class to
- string|null
$class
optional null - The class name being added.
- string
$key
optional 'class' - the key to use for class.
Returns
arrayArray of options with $key set.
getView()source public
getView( )
Get the view instance this helper is bound to.
Returns
Cake\View\View
The bound view instance.
initialize()source public
initialize( array $config )
Constructor hook method.
Implement this method to avoid having to overwrite the constructor and call parent.
Parameters
- array
$config
- The configuration settings provided to this helper.
Methods used from Cake\Core\InstanceConfigTrait
_configDelete()source protected
_configDelete( string $key )
Deletes a single config key.
Parameters
- string
$key
- Key to delete.
Throws
Cake\Core\Exception\Exception
if attempting to clobber existing config
_configRead()source protected
_configRead( string|null $key )
Reads a config key.
Parameters
- string|null
$key
- Key to read.
Returns
mixed_configWrite()source protected
_configWrite( string|array $key , mixed $value , boolean|string $merge = false )
Writes a config key.
Parameters
- string|array
$key
- Key to write to.
- mixed
$value
- Value to write.
- boolean|string
$merge
optional false True to merge recursively, 'shallow' for simple merge, false to overwrite, defaults to false.
Throws
Cake\Core\Exception\Exception
if attempting to clobber existing config
config()source public deprecated
config( string|array|null $key = null , mixed|null $value = null , boolean $merge = true )
Gets/Sets the config.
Usage
Reading the whole config:
$this->config();
Reading a specific value:
$this->config('key');
Reading a nested value:
$this->config('some.nested.key');
Setting a specific value:
$this->config('key', $value);
Setting a nested value:
$this->config('some.nested.key', $value);
Updating multiple config settings at the same time:
$this->config(['one' => 'value', 'another' => 'value']);
Deprecated
3.4.0 use setConfig()/getConfig() instead.Parameters
- string|array|null
$key
optional null - The key to get/set, or a complete array of configs.
- mixed|null
$value
optional null - The value to set.
- boolean
$merge
optional true - Whether to recursively merge or overwrite existing config, defaults to true.
Returns
mixedConfig value being read, or the object itself on write operations.
Throws
Cake\Core\Exception\Exception
When trying to set a key that is invalid.
configShallow()source public
configShallow( string|array $key , mixed|null $value = null )
Merge 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
- string|array
$key
- The key to set, or a complete array of configs.
- mixed|null
$value
optional null - The value to set.
Returns
$this
getConfig()source public
getConfig( string|null $key = null , mixed $default = null )
Returns the config.
Usage
Reading the whole config:
$this->getConfig();
Reading a specific value:
$this->getConfig('key');
Reading a nested value:
$this->getConfig('some.nested.key');
Reading with default value:
$this->getConfig('some-key', 'default-value');
Parameters
- string|null
$key
optional null - The key to get or null for the whole config.
- mixed
$default
optional null - The return value when the key does not exist.
Returns
mixedConfig value being read.
setConfig()source public
setConfig( string|array $key , mixed|null $value = null , boolean $merge = true )
Sets 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
- string|array
$key
- The key to set, or a complete array of configs.
- mixed|null
$value
optional null - The value to set.
- boolean
$merge
optional true - Whether to recursively merge or overwrite existing config, defaults to true.
Returns
$this
Throws
Cake\Core\Exception\Exception
When trying to set a key that is invalid.
© 2005–present The Cake Software Foundation, Inc.
Licensed under the MIT License.
CakePHP is a registered trademark of Cake Software Foundation, Inc.
We are not endorsed by or affiliated with CakePHP.
https://api.cakephp.org/3.6/class-Cake.View.Helper.UrlHelper.html