想把代码块移到另一个文件?vscode 一键移动!

2023 年 9 月,vscode 支持了

一键把一段代码从一个文件移到另一个文件,且同步更新所有引用和 import

话不多说,大家看官网的 GIF,问题我会在后面指出

操作流程

第一步,点击变量,看到灯泡

第二步, 点击灯泡,选择 Move to file

第三步,选择一个文件,比如 hero.model.ts

第四步,查看 git 变化,路径会自动更改,代码也会移到目标文件

第五步,解决问题

  • 查看目标文件里之前是不是 import 过要移动的代码,这里就是 HeroBase,如果有,把 import 删掉。 这应该是个 bug,不过幸好影响范围不那么大,一次操作只有一个文件可能有问题。
  • import 不会自动去重,比如

如果把 bar 移到 b.ts 里,会出现 x 的重复 import

  • 另一个似乎不影响的小问题,要移动的代码下面的注释也没了,移过去的地方也没有。不过如果注释下面还有代码,这个注释就不会动。

实话说,有了这个功能,移动代码,会省事很多,但目前使用还是建议测试下再提交代码!

其他的重构技巧

选中变量名或文件名, F2 重命名,也会自动同步修改所有引用!

如果想先预览下,Shift+Enter

当然,这个是不是真的能替换所有引用,跟你的项目和框架也有些关系。 像 Angular template 上的变量,经常就无法自动更新。

重构里面的其他选项

选中一段代码,右击,点击 重构或 Refactor

你就能看到一堆重构技巧!

尽情享受!

发布原文

相关推荐
慧一居士2 分钟前
VueUse 功能介绍使用场景及完整使用示例
前端·vue.js
奇怪的猫2 分钟前
浏览器窗口最小化的时候,setInterval 执行变慢,解决方案
前端·javascript
多租户观察室2 分钟前
工作流新生态:2026年工作流与Coding的重新分工
前端·人工智能·后端·低代码
cmd4 分钟前
别再混淆了!JS类型转换底层:valueOf vs toString vs Symbol.toPrimitive 详解
前端·javascript
Carsene18 分钟前
开源项目文档架构设计:Git Submodule 实现文档与代码的优雅分离
前端·后端
Z思学21 分钟前
promise 有几种状态 async/await 和promise 有什么关系
前端
han_23 分钟前
JavaScript设计模式(四):发布-订阅模式实现与应用
前端·javascript·设计模式
276695829225 分钟前
租车帮(悟空)订单查询算法分析
java·服务器·前端·悟空·悟空app·租车帮·租车帮逆向
__雨夜星辰__37 分钟前
TypeScript 入门学习笔记(面向对象 + 常用设计模式)
前端·学习·typescript
晚霞的不甘1 小时前
HarmonyOS ArkTS 进阶实战:深入理解边距、边框与嵌套布局
前端·计算机视觉·华为·智能手机·harmonyos