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 上报告任何问题。

欢迎提交拉取请求。

编辑推荐精选

GPT Plus|Pro充值

GPT Plus|Pro充值

GPT充值

支持 ChatGPT Plus / Pro 充值服务,支付便捷,自动发货,售后可查。

GPT Image 2中文站

GPT Image 2中文站

AI 图片生成平台

GPT Image 2 是面向用户的 AI 图片生成平台,支持文生图、图生图及多模型创意工作流。

Vecbase

Vecbase

你的AI Agent团队

Vecbase 是专为 AI 团队打造的智能工作空间,将数据管理、模型协作与知识沉淀整合于一处。算法、产品与业务在同一平台无缝协同,让从数据到 AI 应用的落地更快一步。

音述AI

音述AI

全球首个AI音乐社区

音述AI是全球首个AI音乐社区,致力让每个人都能用音乐表达自我。音述AI提供零门槛AI创作工具,独创GETI法则帮助用户精准定义音乐风格,AI润色功能支持自动优化作品质感。音述AI支持交流讨论、二次创作与价值变现。针对中文用户的语言习惯与文化背景进行专门优化,支持国风融合、C-pop等本土音乐标签,让技术更好地承载人文表达。

QoderWork

QoderWork

阿里Qoder团队推出的桌面端AI智能体

QoderWork 是阿里推出的本地优先桌面 AI 智能体,适配 macOS14+/Windows10+,以自然语言交互实现文件管理、数据分析、AI 视觉生成、浏览器自动化等办公任务,自主拆解执行复杂工作流,数据本地运行零上传,技能市场可无限扩展,是高效的 Agentic 生产力办公助手。

lynote.ai

lynote.ai

一站式搞定所有学习需求

不再被海量信息淹没,开始真正理解知识。Lynote 可摘要 YouTube 视频、PDF、文章等内容。即时创建笔记,检测 AI 内容并下载资料,将您的学习效率提升 10 倍。

AniShort

AniShort

为AI短剧协作而生

专为AI短剧协作而生的AniShort正式发布,深度重构AI短剧全流程生产模式,整合创意策划、制作执行、实时协作、在线审片、资产复用等全链路功能,独创无限画布、双轨并行工业化工作流与Ani智能体助手,集成多款主流AI大模型,破解素材零散、版本混乱、沟通低效等行业痛点,助力3人团队效率提升800%,打造标准化、可追溯的AI短剧量产体系,是AI短剧团队协同创作、提升制作效率的核心工具。

seedancetwo2.0

seedancetwo2.0

能听懂你表达的视频模型

Seedance two是基于seedance2.0的中国大模型,支持图像、视频、音频、文本四种模态输入,表达方式更丰富,生成也更可控。

nano-banana纳米香蕉中文站

nano-banana纳米香蕉中文站

国内直接访问,限时3折

输入简单文字,生成想要的图片,纳米香蕉中文站基于 Google 模型的 AI 图片生成网站,支持文字生图、图生图。官网价格限时3折活动

扣子-AI办公

扣子-AI办公

职场AI,就用扣子

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

下拉加载更多