活动预告

Mac的VIM中delete键失效的原因和解决方案

卢钧轶 2015-04-30 20:46:00
闲扯:在Mac的键盘上实际是没有backspace这个键的。其实Mac的delete就是Windows的backspace,实现的都是向左删除的功能。Mac上如果要实现向右删除的功能需要使用⌘+delete组合键来使用。

原因

网上搜到了很多答案但是现象和解决方案都不同,例如:

博主这里遇到的是第三种情况。每次从normal模式再次进入insert模式后,delete就再也无法向左删除。取而代之的是Mac那蛋疼的duang,duang,duang警告声。如果你是伸手党,只想知道怎么解决的话,那么通关密码是在~/.vimrc中加上set backspace=2。恭喜!你的问题就此解决。(如果问题还在,建议仔细将自己delete键行为和上述三种情况做比对,点击链接对症下药)

博主是个较真且喜欢知道为什么的人。如果你也想知道这个恼人的duang,duang,duang到底是什么原因产生的话,那么让我们往下看。 出现这个问题,基本是因为你的VIM使用了compatible模式,或者把backspace变量设置为空了。好奇的读者一定会问,这两个配置又代表了什么意思?其实compatible模式是VIM为了兼容vi而出现的配置,它的作用是使VIM的操作行为和规范和vi一致,而这种模式下backspace配置是空的。即意味着backspace无法删除indentend of linestart这三种字符。如果你出现了和博主一样的情况,不妨在解决问题前先在VIM中用set backspace?命令查看下自己当前的删除模式。你会看到如下的情况: cmd result

效果就相当于delete只能删除本次insert模式中输入的字符。那么为什么backspace=2又能解决问题呢?其实这个命令是set backspace=indent,eol,start的简化写法,也就相当于把delete键配置成增强模式。具体数值和对应增强模式的对应关系见 vim官方文档,简单摘录如下:

  • 0 same as “:set backspace=” (Vi compatible)
  • 1 same as “:set backspace=indent,eol”
  • 2 same as “:set backspace=indent,eol,start”

Reference

  1. http://stackoverflow.com/questions/10727392/vim-not-allowing-backspace?answertab=active#tab-top
  2. http://unix.stackexchange.com/questions/60057/vim-backspace-not-working-normally
  3. http://vim.wikia.com/wiki/Backspace_and_delete_problems
  4. http://askubuntu.com/questions/296385/backspace-in-insert-mode-in-vi-doesnt-erase-the-character
  5. http://stackoverflow.com/questions/18777705/vim-whats-the-default-backspace-behavior