phpstorm-attributes

phpstorm-attributes

PhpStorm中的PHP 8属性集优化代码分析与完成

phpstorm-attributes项目为PhpStorm提供了一套PHP 8属性,用于增强代码完成和静态分析功能。这些属性包括Deprecated、ArrayShape、ObjectShape、Immutable、Pure、ExpectedValues、NoReturn和Language,能够帮助开发者更准确地定义和分析代码结构。通过使用这些属性,开发者可以提高代码质量,优化开发体验,从而提升PHP编程的效率和准确性。

PhpStormPHP属性代码补全静态分析开发工具Github开源项目

JetBrains官方项目

PhpStorm属性

在PhpStorm中使用这些PHP 8属性可以获得更高级的代码补全和分析。

了解更多信息,请查看博客文章

安装

这些属性在PhpStorm 2020.3及以后版本中可用。它们已经与PhpStorm捆绑在一起,所以你不需要单独安装。

如果你正在使用其他静态分析工具,并且不想遇到"找不到类"的问题,那么你可能需要将属性包作为开发依赖添加到你的composer.json中:

composer require --dev jetbrains/phpstorm-attributes

#[Deprecated]

当你想通知用户某个实体将在未来被移除时,使用此属性。

reason中提供解释提示,在replacement中提供更新建议。

#[Deprecated( reason: '自Symfony 5.2起,请使用setPublic()代替', replacement: '%class%->setPublic(!%parameter0%)' )]

Deprecated

#[ArrayShape]

当你处理类对象数组并想为值指定键名和类型以获得更好的编码辅助时,使用Array Shape。

#[ArrayShape([ // 'key' => 'type', 'key1' => 'int', 'key2' => 'string', 'key3' => 'Foo', 'key3' => App\PHP8\Foo::class, ])] function functionName(...): array

如果在一行中指定,该属性可与PHP ≤ 7.4一起使用。

ArrayShape

#[ObjectShape]

该属性指定可能的对象字段名称及其类型。如果应用,IDE将建议指定的字段名称并推断指定的类型。

#[ObjectShape(["age" => "int", "name" => "string"])] function functionName(): object {...} $obj = functionName();

这种用法实际上意味着$obj有2个字段,名称为agename,相应的类型为intstring

#[Immutable]

如果你想保证属性或整个对象在初始化后不会被改变,请使用此属性标记它们。

#[Immutable] class DTO { public string $val; public function __construct(string $val) { $this->val = $val; } }

如果在一行中指定,该属性可与PHP ≤ 7.4一起使用。

Immutable

#[Pure]

对不产生任何副作用的函数使用此属性。所有这样的PHP内部函数在PhpStorm中已经被标记。

#[Pure] function compare(Foo $a, Foo $b): int { return $a->a <=> $b->b; }

Pure

#[ExpectedValues]

使用此属性来指定函数确切接受哪些值作为参数以及它可以返回哪些值。这将改善编码辅助。

function response( #[ExpectedValues(valuesFromClass: Response::class)] $httpStatusCode, //... ) { //... }

ExpectedValues

#[NoReturn]

用此属性标记终止脚本执行的函数作为退出点,以获得更准确的控制流分析。

#[NoReturn] function redirect(): void { //... exit(); }

NoReturn

#[Language]

添加此属性以标记包含其他[编程]语言文本的字符串参数,例如RegExp、SQL等。这将改善高亮显示并为你揭示PhpStorm的其他功能。

Language

错误和功能请求

请在PhpStorm问题跟踪器 https://youtrack.jetbrains.com/newIssue?project=WI 上报告任何问题。

欢迎提交拉取请求。

编辑推荐精选

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
商汤小浣熊

商汤小浣熊

最强AI数据分析助手

小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。

imini AI

imini AI

像人一样思考的AI智能体

imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。

Keevx

Keevx

AI数字人视频创作平台

Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。

即梦AI

即梦AI

一站式AI创作平台

提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作

扣子-AI办公

扣子-AI办公

AI办公助手,复杂任务高效处理

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

下拉加载更多