PHP 8.0
View available context actions: AltEnter
Configure PHP code inspections: Editor | Inspections | PHP
Configure PHP language level and project interpreter: PHP
PHP 8.0 brings new features, syntax additions, and bugfixes. For more information about new functionality in this version, refer to the release announcement. For more information about migrating your code, refer to the Migrating from PHP 7.4.x to PHP 8.0.x guide.
Named arguments allow passing arguments to a function based on the parameter name rather than position. This way, function calls become self-documenting and arguments order becomes arbitrary.
In a function call, you can use the provided quick-fix AltEnter to add parameter names either one by one or to all arguments at once. If there are arguments in the list whose passed value matches the default value, PhpStorm highlights them as unused and provides a quick-fix to delete them.
data:image/s3,"s3://crabby-images/ea54f/ea54f64bdb40ecdbcb527cf5ca72650ba2381b6a" alt="https://resources.jetbrains.com/help/img/idea/2024.3/ps_add_named_arguments.png"
With attributes, you can provide structured, syntactic metadata to declarations of classes, properties, functions, and so on. Unlike PHPDoc comments, attributes are supported and validated on the language level.
To create an attribute, add the #[Attribute]
marker on top of a class declaration. Inside the attribute, optionally provide the target and repeatability flags. To use code completion, press CtrlSpace.
data:image/s3,"s3://crabby-images/a8007/a80078b824fb0fa6b3c26f771cb1535536011347" alt="https://resources.jetbrains.com/help/img/idea/2024.3/ps_create_php_attribute.png"
Several code inspections help to ensure that attributes are used correctly:
The Class cannot be used as attribute inspection verifies that a class is annotated with
#[Attribute]
in its arguments declaration.The Non-applicable attribute target declaration inspection verifies that the attribute is annotated with
#[Attribute::Target]
in its arguments declaration, and is therefore applied to the correct target such as a class or a method,The Non-repeatable attribute inspection highlights attributes that are repeated without the
Attribute::IS_REPEATABLE
flag set in its arguments declaration.
note
PhpStorm provides custom open-source PHP 8 attributes. To use them in your project, add a
jetbrains/phpstorm-attributes
Composer dependency as described in Install Composer dependencies.
A Union Type accepts values of multiple different types rather than a single one. Union types are specified as Type1|Type2|...
and can be used in all places where regular types are accepted. All existing PhpStorm coding assistance features fully support union types.
If a union type is provided via PHPDoc, PhpStorm offers a quick-fix AltEnter for converting it to a native union type.
data:image/s3,"s3://crabby-images/7f83c/7f83cf59949eb61d566ea17d8785020833835c91" alt="https://resources.jetbrains.com/help/img/idea/2024.3/ps_convert_phpdoc_union_to_native.png"
With natively declared union types, PhpStorm can analyze calls and detect problem areas. The checks work on all levels: properties, arguments, and return values.
data:image/s3,"s3://crabby-images/c5904/c59042e19eb8f4c38d4777a72e6179f6493503ea" alt="Type checks in union type declaration Type checks in union type declaration"
With Constructor property promotion, you can declare and initialize class properties directly in the constructor. If you provide a visibility modifier such as public
, protected
, or private
to a constructor argument, the argument will be interpreted as an object property and its value will be assigned to this property. This makes objects smaller and more readable and helps reducing the amount of boilerplate code in cases where you initialize variables through a constructor.
You can convert constructor arguments to promoted properties with a quick-fix AltEnter.
data:image/s3,"s3://crabby-images/545b1/545b1287856e4520dbc308544efd5327fd8e3cad" alt="https://resources.jetbrains.com/help/img/idea/2024.3/ps_converting_to_promoted_properties.png"
PhpStorm verifies that promoted properties are used in accordance with the PHP 8 constraints. For example, a promoted property cannot be declared outside a constructor or inside an abstract constructor, and variadic parameters cannot be promoted.
data:image/s3,"s3://crabby-images/e797e/e797e05aa71e81cd3201f5c2f0ef64529efe17c9" alt="Promoted properties checks Promoted properties checks"
A match expression is similar to switch
but provides safer semantics and can return a value. PhpStorm detects switch
statements that can be converted to match
expressions and provides a dedicated quick-fix AltEnter to do this.
data:image/s3,"s3://crabby-images/0ac99/0ac995493e2c02a7d75a1c69f00006944ad693fe" alt="https://resources.jetbrains.com/help/img/idea/2024.3/ps_convert_switch_to_match.png"
Several code inspections help to ensure that match
expressions are used correctly:
If the expression argument's type does not match any of the specified conditions, the expression will cause a
Fatal Error
. In such cases, you can add adefault
arm by using the provided quick-fix.GifThe Unused 'match' condition inspection highlights the conditions that are never matched and suggests deleting them.
The Unused condition inspection detects duplicate conditions that will never run. You can navigate between them and remove either the entire arm or only the duplicate value from a list of values.
GifThe Duplicate arm in 'match' expression inspection detects identical bodies in different arms, which can be merged into one to reduce the size of the block.
GifThe 'match' expression can be replaced with ternary expression inspection will detect expressions with a single arm and a
default
arm and let you replace them with ternary expressions.GifIf a match expression only has a default arm, then it is probably redundant. The Redundant 'match' expression inspection will highlight such expressions and let you remove them.
Gif
With the nullsafe operator ?->
, you can replace nested null check conditions with chained calls.
data:image/s3,"s3://crabby-images/172ba/172babe16d23d216fccf9c7db114975a6064c621" alt="Using the nullsafe operator Using the nullsafe operator"
PhpStorm verifies that the nullsafe operator is not erroneously used in write context or as a reference.
data:image/s3,"s3://crabby-images/30109/30109595bf34219a365b4e02d80eddd67680ba63" alt="Nullsafe operator inspections checks Nullsafe operator inspections checks"
Starting with PHP 8, you can catch exceptions without capturing them to variables. The Unused local variable inspection detects the variables that are not used inside the catch
statement and provides a quick-fix AltEnter to remove them:
data:image/s3,"s3://crabby-images/af2d0/af2d034da7280e5c566edb5ef73fb8ad51ee20a3" alt="Nullsafe operator inspections checks Nullsafe operator inspections checks"
In PHP 8, throwing exceptions is allowed in all places where expressions are accepted, for example, in arrow functions, the coalesce operator ??
, and the ternary operator ?:
. PhpStorm provides a live template that lets you quickly add a throw
expression. To apply it, type thr
and press Tab.
data:image/s3,"s3://crabby-images/b1387/b138703b74915899e1940b08511c099801efa89f" alt="https://resources.jetbrains.com/help/img/idea/2024.3/ps_throw_exception.png"
In previous PHP versions, to get a class FQN, you could use ClassName::class
. On objects, however, you had to call get_class()
. In PHP 8, get_class()
calls can be safely replaced with $object::class
. PhpStorm provides a quick-fix AltEnter for this and will also warn if ::class
is used inappropriately.
data:image/s3,"s3://crabby-images/1710b/1710bc86a6da5732c9fbcd656acf5a12308ec3ac" alt="https://resources.jetbrains.com/help/img/idea/2024.3/ps_class_on_object.png"
PHP 8 introduces several new functions for working with strings. The str_contains function checks whether a string is contained in another string. The str_starts_with and str_ends_with functions are used for determining if a string starts or ends with a specific substring. The 'str*' calls can be replaced with PHP 8 'str_*' calls inspection highlights the strpos
and substr
calls that can be replaced with their modern and more self-explanatory alternatives and provides the corresponding quick-fixes AltEnter.
data:image/s3,"s3://crabby-images/e27ec/e27ec3bd9002bdc878360b9b9b415f135a6f9e59" alt="https://resources.jetbrains.com/help/img/idea/2024.3/ps_strings_functions.png"