3 月 28 日,WebStorm v2023.1 版本正式发布,这是 WebStorm 2023 年的第一个主要版本!此版本包括许多新功能和对 IDE 的改进。
v2023.1 中的主要新功能和改进包括:
框架和技术:Astro 支持、Vue 改进、复制粘贴时添加的组件导入、React 属性的形参信息、将全局符号和导出符号自动导入 Angular 模板、Svelte 错误修复等。
JavaScript 和 TypeScript:将字符串自动转换为模板文字,为自动导入更好地确定导入库的优先级,在 TypeScript 和 JavaScript 之间对齐导入行为等。
HTML和 CSS:Tailwind CSS 配置、配置 HTML 代码完成的选项、在 Markdown 文件中重新格式化表格的能力等。
全新 UI:工具窗口的垂直拆分、紧凑模式、macOS 上的项目选项卡、重新设计的 run 小部件等。
用户体验:完整的 IDE 缩放、每个工具窗口设置的新记住大小、为新项目配置保存操作的设置、在智能模式下扫描文件以建立索引等。
版本控制:改进了 GitHub 的代码审查工作流程、Structure 工具窗口中的 VCS 状态颜色提示、改进的 Branches 弹出窗口等。
备受期待的 Astro 支持已登陆 WebStorm!从 Preferences / Settings | Plugins(偏好设置/设置 | 插件)安装新的 Astro 插件即可获取。插件提供基本功能,包括语法高亮显示、带自动导入的代码补全、重构、导航、正确的格式设置等。
本版本在 Vue 模板中添加了对 TypeScript 支持。它会在将 script 标记中的 lang 特性设为 ts 时启用。此前,无论 script 标记中的 lang 特性如何,使用的都是 JavaScript。WebStorm 现在将提供对内联转换的支持、改进的类型缩小,并在 Vue 单文件组件模板的快速文档中提供正确的推断类型信息。
这个版本中还有一项 Vue 特定的改进值得关注。现在可以在 Vue 模板中获得自定义组件事件的代码补全。它在 JavaScript 和 TypeScript 中相同。
将代码从一个文件复制粘贴到另一个文件时,WebStorm 会自动添加所有必需 import。此前纯 JavaScript、TypeScript 语言和 React 模板是这种形式。在 WebStorm 2023.1 中,它现在也适用于 Vue、Svelte、Astro 和 Angular 模板。
本版本添加了一种新方式来显示组件属性的预期类型。如果在将属性传递给组件时按 ⌘P,将看到一个包含类型信息的弹出窗口。此前,这些信息只能通过悬停显示,对于主要使用键盘的用户来说很不方便。
在 Angular 模板中,WebStorm 会在代码补全时自动将全局和导出符号的 import 添加到组件中。IDE 还支持 Angular 15 NgoptimizedImage 指令,提供了建议对 img 使用 ngSrc 而不是 src 的检查。
现在可以通过右键点击上下文菜单在特定文件夹中运行所有测试。这个功能此前适用于 Vitest,现在也已为 Jest 实现。
现在,WebStorm 在输入 ${
时会自动将带单引号或双引号的字符串转换为模板文字。这适用于原始字符串以及 JSX 属性。
从具有相同导出元素名称的不同库添加自动导入时,IDE 的行为有所改进。自动导入现在根据项目中的现有导入添加。如果需要为来自另一个库的元素添加 import,则必须手动添加 import 语句。WebStorm 将像先前版本一样提供弹出窗口。
统一了 TypeScript 与 JavaScript 之间的导入行为。在 TypeScript 中,将在上下文操作中看到导入选项,就像在 JavaScript 中看到的一样。按 ⌥ ⏎ 即可打开上下文操作。统一的设置位于 Preferences / Settings | Editor | General | Auto Import(偏好设置/设置 | 编辑器 | 常规 | 自动导入)。
WebStorm 包括对新推出的 TypeScript 5.0 中主要功能的支持。它还提供了对多重配置继承、类型形参的 const 修饰符和 allowImportingTsExtensions 标志的完全支持。
在 v2023.1 中改进了 WebStorm 处理 JavaScript、TypeScript、HTML、CSS 和各种框架中的引用的方式。现在,引用的处理方式在项目间更加通用。例如,解析图像、CSS 或 HTML 文件现在可以使用路径别名。
在这个版本中添加了对配置选项的支持,例如 classAttributes 选项下的自定义类名补全或 tailwindCSS.experimental.configFile 等实验性选项。可以在 Preferences / Settings | Languages & Frameworks | Style Sheets | Tailwind CSS(偏好设置/设置 | 语言和框架 | 样式表 | Tailwind CSS)下设置这些配置选项。
WebStorm 2021.3 为 HTML 引入了补全,会在输入时显示标记名称或缩写。在 HTML 中输入纯文本时,这种行为可能会分散注意力,因此添加了将其禁用的选项。可以在 Preferences / Settings | Editor | General | Code Completion(偏好设置/设置 | 编辑器 | 常规 | 代码补全)中找到新选项。
现在可以使用快速修复更正 Markdown 表的格式。此外,使用新增的 Fill Paragraph(填充段落)编辑器操作可以将长文本轻松分为几个等宽的行。最后,在 Preferences / Settings | Editor | General | Smart Keys(偏好设置/设置 | 编辑器 | 常规 | 智能按键)下引入了专属 Markdown 设置选项页面。
Preferences / Settings | Editor | Code Style | Style Sheets | CSS | PostCSS(偏好设置/设置 | 编辑器 | 代码样式 | 样式表 | CSS | PostCSS)中的新选项允许指定在 PostCSS 文件中使用的行注释样式。可以使用 ⌘/ 通过选择的行注释样式注释掉行。
去年为 WebStorm 和其他 JetBrains IDE 引入了更简约的新 UI。可以前往 Preferences / Settings | Appearance & Behavior | New UI(偏好设置/设置 | 外观与行为 | 新 UI)选择。
WebStorm 2023.1 支持分割和排列工具窗口,从而同时显示两个工具窗口。将工具窗口图标从边栏拖动到分隔符下方。或者可以右键点击图标,使用 Move to(移至)操作为工具窗口分配新位置。
本版本引入了紧凑模式,使较小屏幕上的工作体验更加舒适。它简化了工具栏和工具窗口标题,缩小了间距、填充以及图标和按钮,提供更为统一的外观。转到主菜单中的 View | Appearance | Compact Mode(视图 | 外观 | 紧凑模式)即可打开新模式。
为 macOS 用户实现了新 UI 中最热门的功能请求之一——项目标签页。有多个打开的项目时,现在可以使用主工具栏下显示的项目标签页切换。
基于有关 IDE 新 UI 的反馈,重新设计了主窗口标题中的 Run(运行)微件,使其更加自然悦目。
在新 UI 中添加了一些用户期待的热门功能。例如,Show Hidden Tabs(显示隐藏的标签页)选择器和 Branches(分支)弹出窗口中的 Fetch(提取)操作均已回归。另外,还通过隐藏主工具栏元素并在作用域中显示文件的名称改进了 Distraction Free(无干扰)和 Zen 模式。
现在可以放大和缩小 WebStorm,同时增加或缩减所有 UI 元素的大小。从主菜单中,选择 View | Appearance | Switch Zoom IDE(视图 | 外观 | 切换缩放 IDE)。还可以按 ⌃` 并通过 Zoom(缩放)调整 IDE 的缩放比例。
本版本引入了一个新的布局选项,允许统一侧面工具窗口的宽度或保留在自定义布局时调整其大小的能力。新的 Remember size for each tool window(记住每个工具窗口的大小)复选框位于 Preferences / Settings | Appearance & Behavior | Appearance | Tool Windows(偏好设置/设置 | 外观与行为 | 外观 | 工具窗口)中。
WebStorm 2023.1 添加了为新项目预定义 Actions on Save(保存时的操作)行为的选项。转到 File | New Projects Setup | Preferences / Settings For New Projects | Tools | Actions on Save(文件 | 新项目设置 | 新项目偏好设置/新项目设置 | 工具 | 保存时的操作),选择在未来项目中保存更改时要触发的操作。
为了提供更有意义和更准确的搜索结果,本版本将机器学习排名进一步集成到 Search Everywhere(随处搜索)(Double ⇧)功能中。Classes(类)标签页中的排序算法现在也默认由机器学习驱动,与 Actions(操作)和 Files(文件)标签页中的结果相同。
本版本新增了一个选项,用于将复制-剪切-粘贴行为还原到早期版本的 WebStorm 中的行为。这允许将剪贴板内容粘贴到文本光标处,而不是粘贴到前一行。这个选项位于 Preferences / Settings | Advanced Settings | Editor(偏好设置/设置 | 高级设置 | 编辑器)下的 When pasting a line copied with no selection(粘贴复制时未选择内容的行时)下拉菜单中。
通过在智能模式下执行 Scanning files to index...(正在扫描要建立索引的文件)进程改进了 IDE 启动体验,这应该会减少启动时等待索引所造成的延迟。打开项目时,WebStorm 将使用项目在上一个会话中的现有缓存,并查找要建立索引的新文件。如果扫描时未发现更改,IDE 将准备就绪。
WebStorm 2023.1 包含一个新通知,会在启用 Microsoft Defender 实时保护时触发。WebStorm 会建议将特定文件夹添加到 Defender 的排除项列表中,因为这些防病毒检查会显著降低 IDE 的速度。
为了简化在 IDE 中审查代码的过程,重做了 Pull Request(拉取请求)工具窗口。它现在为打开的每个拉取请求提供一个专用标签页。标签页会立即显示已更改文件的列表,并且有一个专用按钮可以根据拉取请求的当前状态执行最相关的操作。
在 WebStorm 2023.1 中,在 Create New Branch(创建新分支)弹出窗口中实现了自动补全。为新分支输入名称时,IDE 将根据现有本地分支的名称建议相关前缀。
改进了 Branches(分支)弹出窗口的实用性。分支被分组并存储在可扩展列表中,导航更加轻松。
在 Structure(结构)工具窗口中添加了颜色提示,使文件更改更易于跟踪。被修改对象的名称现在为蓝色,新添加对象的名称在工具窗口中显示为绿色。
重做了 Git 和 Mercurial 提交检查的行为,旨在加快整个提交过程。检查将在提交之后且推送之前在后台执行。