当前位置:首页 > 技术分析 > 正文内容

高效使用 Vim 编辑器的 10 个技巧

ruisui885个月前 (01-10)技术分析38

在 Reverb,我们使用 MacVim 来标准化开发环境,使配对更容易,并提高效率。当我开始使用 Reverb 时,我以前从未使用过 Vim。我花了几个星期才开始感到舒服,但如果没有这样的提示,可能需要几个月的时间。这里有十个技巧可以帮助你在学习使用 Vim 时提高效率。

1. 通过提高按键重复率来更快地导航

转到系统偏好设置-> 键盘,增加您的按键重复,并缩短您的延迟直到重复。这将让您使用 hkjl 更快地导航(不要使用那些箭头键!)

2.使用gg/G和ctrl-d/ctrl-u垂直导航

垂直导航最简单的方法是使用 :<line number> 直接跳转到您需要的行号。有时您不知道该行号,因此您可以使用 ctrl-u 和 ctrl-d 快速上下“翻页”。需要遍历整个文档?使用 gg 快速跳转到文档顶部或使用 G 跳转到底部。

3. 使用 0 和 $ 水平导航

水平导航的方法有很多,但对我最有帮助的总是 0,它会将您带到行首,而 $,它会将您带到行尾。

4.通过重新绑定大写锁定(或使用 ctrl-c)更快地逃脱

如果 Vim 就是为了让你的手指尽可能靠近键盘的“主行”,那么为什么将转义映射到如此重要的功能呢?使用键绑定程序(混响是Seil的一部分)将转义映射到大写锁定或开始使用 ctrl-c,这是转义的默认替代方法。

5.与c同时删除和切换到插入模式

同理,d 是 Vim 的“动词”,表示删除,c 是动词,表示变化。c 允许您删除并立即进入插入模式。例如,“ct”删除所有内容,直到下一个空格并进入插入模式。'c#39; 做同样的事情直到行尾。

6. 使用 / 搜索并使用 n 和 N 导航

cmd-f 的 Vim 等效项是 / 后跟您要查找的术语。搜索完一个词后,用 n 转到下一个实例,用 N 转到前一个实例。

7. 搜索并替换为 :%s

如果你需要替换一个术语,你可以使用稍微复杂一些的 :%s 命令,它的结构如下:

:%s/<term to replace>/<replacement>/<flags>

例如,如果您想查找“grey”并将其替换为“gray”,则可以使用:%s/grey/gray。然而不幸的是,默认情况下,这只会替换每行中术语的第一个实例。使用 g 标志替换第一项的所有实例,无论每行有多少。

你也可以使用 c 标志让 Vim 在替换之前确认每个实例。所以 :%s/grey/gray/gc 将找到“grey”的每个实例,并要求您确认是否希望将其替换为“gray”。

8. 使用 ctrl-o 和 ctrl-i 跳转到以前访问过的位置

Vim 会跟踪您在文件中的位置,包括跨文件。每次更改文件或打开新文件时,都会存储该位置。您可以使用 ctrl-o 跳转到以前访问过的位置。同样,您可以使用 ctrl-i 向前跳转。这意味着如果您在同一个选项卡或窗口中处理两个文件(没有屏幕分割),您可以使用 ctrl-o 和 ctrl-i 在它们之间轻松导航。

9.用gf去其他文件

当您将光标放在另一个文件的名称中时,您可以按 gf 跳转到该文件。由于将文件命名为与它们定义的类相同的常见做法,这特别有用。为了提高效率,请参阅下一个提示。

10.使用插件

标准 Vim 非常强大,但它的很大一部分功能在于它的可定制性。像 NerdTree 和 CtrlP 这样的文件导航插件可能是一些最容易访问的工作流程更改插件,但请做一些研究!那里有一吨。在 Reverb,我们使用YADR,这是一个 dotfile repo,它极大地增强了 MacVim 和终端的功能(特别是对于 Rails 开发人员)。

希望您今天学到了有关如何最有效地使用 Vim 的新知识。使用 Vim,您越简化您的工作流程,您就会越舒适。如果您有任何自己的建议,请给我们留言!

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/149.html

标签: nerdtree
分享给朋友:

“高效使用 Vim 编辑器的 10 个技巧” 的相关文章

企业如何高效进行费控管理?

作为一个职场人,无论是普通员工、财务人员还是企业管理人,都无法避开报销,而报销,就涉及到了企业成本费用控制,即费控。其控制的内容包括材料消耗成本控制、工资成本控制、费用成本控制。但在实际工作中,员工不知道如何规范化提交报销申请,报销容易频频被打回,导致报销周期长;财务人员也面临着报表滞后、账实不符、...

深入理解Vue.js组件通信:父子组件与子父组件数据交互详解

什么是Vue组件通讯 Vue.js 组件通信是指在 Vue 应用的不同组件之间进行数据交换和状态同步的过程。由于 Vue 的组件是基于单文件组件(SFCs)的模块化设计,每个组件都有自己的作用域,因此它们不能直接访问彼此的数据。为了使组件之间能够协同工作,Vue 提供了几种不同的通信方式。以下是 V...

gitlab简单搭建与应用

一、gitlab1、简介GitLab是利用Ruby on Rails一个开源的版本管理系统,实现一个自托管的Git项目仓库,可通过Web界面进行访问公开的或者私人项目。与Github类似,GitLab能够浏览源代码,管理缺陷和注释。可以管理团队对仓库的访问,它非常易于浏览提交过的版本并提供一个文件历...

30 个纯 HTML5 实现的游戏

浏览器和 JavaScript 的功能逐年不断的变强变大。曾几何时,任何类型的游戏都需要Flash。但随着 HTML5 发展,HTML5 + WebGL 游戏式就慢慢占领着这个舞台。以下是30款流行的游戏,它们可以在所有现代浏览器中运行,并且只使用web技术构建。1. HexGL地址:http://...

js中数组filter方法的使用和实现

定义filter() 方法创建一个新数组, 其包含通过所提供函数实现的测试的所有元素。语法var newArray = arr.filter(callback(element[, index[, selfArr]])[, thisArg])参数callback循环数组每个元素时调用的回调函数。回调函...

SpringBoot2.X+Vue+UniAPP,全栈开发医疗小程序

//xia仔のke:chaoxingit.com/208/全栈开发医疗小程序:利用Spring Boot 2.X、Vue和UniApp在当今数字化时代,医疗行业也在不断地迈向信息化和智能化的方向。开发一款医疗小程序,能够为用户提供便捷的医疗服务和信息查询,为医疗机构提供高效的管理和服务渠道。本文将介...