我喜欢vim,但一个常见的问题是:
拉起一条线 去你想粘贴的地方 删除已有内容 粘贴你的yank,却发现它粘贴了你刚刚删除的内容
显然,工作流是先删除,再删除。但如果我不这么做就太好了。有人有诀窍吗?vim是否有一个工作良好的粘贴缓冲区,或者是否有一个我可以更改的.vimrc设置?
我喜欢vim,但一个常见的问题是:
拉起一条线 去你想粘贴的地方 删除已有内容 粘贴你的yank,却发现它粘贴了你刚刚删除的内容
显然,工作流是先删除,再删除。但如果我不这么做就太好了。有人有诀窍吗?vim是否有一个工作良好的粘贴缓冲区,或者是否有一个我可以更改的.vimrc设置?
当前回答
默认情况下,所有的yank和delete操作都写入未命名寄存器。然而,最近的yank和最近的delete总是存储在有编号的寄存器中(分开)。寄存器0保存最近的yank。寄存器1-9保存了最近的9个删除(其中1是最近的)。
换句话说,delete覆盖了未命名寄存器中最近的yank,但它仍然存在于0寄存器中。在其他答案中提到的黑洞寄存器技巧(“_dd)之所以有效,是因为它可以防止覆盖未命名的寄存器,但这不是必要的。
你可以使用双引号引用一个寄存器,所以可以像这样粘贴最近拉出的文本:
"0p
这是一个很好的参考:
http://blog.sanctum.geek.nz/advanced-vim-registers/
其他回答
另一种可能性如下:
像平常一样拉你的线 切换到你想要粘贴的位置,进入可视线条模式(V) 选择要替换的行 按p粘贴你的行。
这还有一个额外的好处,即缓冲区与被替换的内容进行了“交换”,我认为这非常方便
如果您是一个恶意用户,您可以考虑重新映射X,以实现与“_d”等价的功能。然而,完善实现对我来说有点棘手。尽管如此,我还是发现
(define-key evil-normal-state-map "X" 'evil-destroy)
(define-key evil-visual-state-map "X" 'evil-destroy)
(evil-define-operator evil-destroy (beg end type register yank-handler)
"delete without yanking text"
(evil-delete beg end type 95 yank-handler)
)
积分很好。例如,输入XX将类似于dd, X$对于d$, X0对于d0,等等……
如果你好奇它是如何工作的,“95”代表“_寄存器”,所以它只是重新路由你的删除调用,就好像“_已经被按下了寄存器。
诀窍是你知道你想要抓取一些东西并移动,你正在使用“lazy”第一个寄存器(它会被你刚刚删除的东西所取代)。
你需要学会在vim中“切割”。
在删除之前,指定与“one.”不同的任何寄存器。提示:用reg检查你的寄存器
现在,通过在任何命令之前按“”(显然是在命令模式下)来选择一个新寄存器
选择你想要“切割”的部分(或者在步骤2中指定一个范围) 将寄存器更改为任何东西(这里是1)并删除:“1d或”1x或甚至“1c” 去新的地方,删除更多 现在你已经准备好粘贴你切割并存储在寄存器1:"1p或"1p
完成了。这也有解决用例的优势:从一个地方删除5个不同的东西,每一块都去了不同的目的地……只要把一个放进“1”,另一个放进“2”,等等……转到每个目标并粘贴。
传递到_寄存器,黑洞。
删除一行而不将其插入寄存器:
"_dd
请参见:帮助寄存器。
这可能是最安全的,如果你想要一遍又一遍地粘贴某个东西,把它拉到一个“命名”寄存器中。
"aY
猛拉一根线到收银台。用“ap”粘贴。
我写了这个插件(洋栈.vim)来解决这个问题。就像Emacs给vim的杀人戒指一样。您可以删除或删除多个内容,进行粘贴,然后在删除/删除文本的历史记录中来回循环。我发现这比记住我把东西放进哪个寄存器要容易得多。
在我的.vimrc中,我有这些映射:
nmap <M-p> <Plug>yankstack_substitute_older_paste
nmap <M-P> <Plug>yankstack_substitute_newer_paste
它可以让我按ALT-p或ALT-SHIFT-p在粘贴历史中来回循环。