摘要:完整配置见可以记录我们最近访问的位置。下方是比当前位置新的位置,使用进行跳转。再多的内容,我也记不住另外,的标记功能对代码浏览也非常方便,有时间再介绍吧。
完整 Vim 配置见:space-vim
Vim 可以记录我们最近访问的位置(location)。每个位置(position)(position 包括了文件名,列号,行号)会被一个 jump list (跳转表)中,每个窗口(window)都有一个多带带的 jump list,它可以记录最近 100 个访问的位置。
像搜索(search), 替换(substitue)和标记(mark)的命令都被认为是一个“jump”(跳转),但是在一个文件中进行滚动并不是一个 jump. 详见 :h jump-motions.
之所以了解 jumplist,是因为在看 go 的项目时,经常查看代码的定义(gd,使用 vim-go 插件),这时就可以使用 Ctrl-I 和 Ctrl-O 进行跳转。看完定义后,Ctrl-O 就可以很快跳回来。
如何使用使用 :jumps 来显示当前窗口的 jump list,由于太长,下图并未显示完,使用 Vim 的常见快捷键进行滚动,j,k,G 等等:
使用 Ctrl-o 跳转到上一个位置,Ctrl-i 跳转到下一个位置。Ctrl-o 和 Ctrl-i 前面也可以加上编号,进行精确跳转,这个编号就是上图中 jump 列的数字。跳转以后再查看 jump list, 你会发现有个 > 指示了当前位置,一开始的时候它是在 jump list 的顶部,如果你的 jump list 比较长的话,可能需要拖到底部(快捷键 G)才能看到:
上图中可以看出,行号为 0 的上下方都是从 1 开始编号,它们分别代表了比当前位置更旧或新的位置。下方是比当前位置新的位置,使用 Ctrl-I 进行跳转。上方是比当前位置旧的位置,使用 Ctrl-O 进行跳转:
Ctrl-I 会跳转到行号为 0 的下方编号为 1 的位置,也就是 1 21 5 type MessageType uint16.
Ctrl-O 会跳转到 1 420 24 ~/go/src/github.com/lightningnetwork/lnd/fundingmanager_test.go
在 Ctrl-I 和 Ctrl-O 同样可以加上数字跳转到对应位置。比如 4 然后 Ctrl-I 会跳转到 5 14 5 ~/go/src/github.com/lightningnetwork/lnd/lnwire/accept_channel.go.
简化操作前面说了可以使用位置的编号加上 Ctrl-I 或 Ctrl-O 跳转到对应位置,Ctrl-I 或 Ctrl-O 这个操作其实可以省略。比如,输入 4 向后跳转到第 4 个位置,输入 +4 向前跳转到第 4 个位置:
function! GotoJump() jumps let j = input("Please select your jump: ") if j != "" let pattern = "vc^+" if j =~ pattern let j = substitute(j, pattern, "", "g") execute "normal " . j . "" else execute "normal " . j . " " endif endif endfunction
你可以选择将这个函数放到你的 .vimrc 中,:call GotoJump() 进行使用。在 space-vim 我将它放在了 util.vim, 可以这样进行调用::call spacevim#util#GotoJump(), 再映射一个快捷键就能比较方便地使用了:
nnoremapgj :call spacevim#util#GotoJump()
其实讲了这么多,只需要学到 C-i 和 C-o 这两个快捷键就行了,一个是跳转到上一个位置,一个是跳转到下一个位置。再多的内容,我也记不住 :).
另外,Vim 的 mark(标记)功能对代码浏览也非常方便,有时间再介绍吧。
参考:
Jumping to previously visited locations
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/24968.html
摘要:插件键位映射技巧性的配置等等都是锦上添花,它们有助于你进一步提高效率以及个性化你的工作环境,但是对于哲学的理解帮助甚少。为你开启语法高亮。你可以自定义各种语言的语法高亮,无非就是根据这些规 如果没有挑战,人生将多么无趣! 两种副本 在我的硬盘上总是保留着(至少)两份 Vim 的配置文件。其中一份是所谓完全正式版,它的文件名是 .vimrc,到本系列结束的时候,我们将了解其中...
摘要:效果效果就像优酷综艺频道页面的图片轮播。本屌之前做过这个参见仿优酷频道首页的图片切换效果不过用的是类似的库做的。 roundabout效果 效果就像优酷综艺频道页面的图片轮播。本屌之前做过这个roundabout,参见仿优酷频道首页的图片切换效果,不过用的是类似jquery的库做的。尽管js代码不到200行,但还是显得有点复杂。于是乎,本屌盘算着可不可以用更少的代码完成这个效果。顺便说...
摘要:效果效果就像优酷综艺频道页面的图片轮播。本屌之前做过这个参见仿优酷频道首页的图片切换效果不过用的是类似的库做的。 roundabout效果 效果就像优酷综艺频道页面的图片轮播。本屌之前做过这个roundabout,参见仿优酷频道首页的图片切换效果,不过用的是类似jquery的库做的。尽管js代码不到200行,但还是显得有点复杂。于是乎,本屌盘算着可不可以用更少的代码完成这个效果。顺便说...
阅读 3077·2019-08-30 15:56
阅读 1234·2019-08-29 15:20
阅读 1571·2019-08-29 13:19
阅读 1473·2019-08-29 13:10
阅读 3381·2019-08-26 18:27
阅读 3069·2019-08-26 11:46
阅读 2234·2019-08-26 11:45
阅读 3753·2019-08-26 10:12