整理了VIM的配置,换上插件管理的神器-----Vundle,由他引发的VIM生态环境的改善,堪称完美。遂打算写一份简单的教程,分享Git时代VIM新世界的美丽动人之处。对VIM有基础的同学,可直接跳至插件管理部分。
第一次使用VIM,会觉得无所适从,他并不像记事本,你敲什么键就显示什么,理解VIM的需要明白他的两种模式: - 命令模式 (Command Mode) - 编辑模式 (Insert Mode)
命令模式下,可以做移动、编辑操作;编辑模式则用来输入。键入i
,o
,s
,a
等即可进入编辑模式,后面解释原因。
模式的设计是VIM和其他编辑器最不同的地方,优势和劣势也全基于此而生。
以下介绍的键盘操作,都是大小写敏感的,并且要在命令模式下完成,需注意:
h
向左移动一个字j
向下移动一行k
向上l
向右这四个键在右手最容易碰到几个位置,最为常用。
w
下一個word w(ord)W
下一個word(跳过标点)b
前一個word b(ackward)B
前一个word(跳过标点)e
跳到当前word的尾端 e(nd)0
跳到当前行的开头^
跳到当前行第一个非空字符$
跳到行尾助记:0(第0个字符),^
和$
含义同正则表达式
{
上一段(以空白行分隔)}
下一段(以空白行分隔)%
跳到当前对应的括号上(适用各种配对符号)/xxxx
搜索xxxx,然后可以用n
下一个,N
上一个移动#
向前搜索光标当前所在的字*
向后搜索光标当前所在的字fx
在当前行移动到光标之后第一个字符x的位置 f(ind)xgd
跳到光标所在位置词(word)的定义位置 g(o)d(efine)gg
到文档顶部G
到文档底部:x
跳到第x行(x是行号)ctrl+d
向下翻页 d(down)ctrl+u
向上翻页 u(p)i
在光标当前位置向前插入 i(nsert)I
在本行第一个字符前插入a
在光标当前位置向后插入 a(fter)A
在本行末尾插入o
向下插入一行O
向上插入一行:w
保存:q
退出:wq
保存并退出x
删除当前字符dd
删除当前行 d(elete)dw
删除当前光标下的词 d(elete)w(ord)yy
复制当前行 y(ank)yw
复制当前光标下的词 y(ank)w(ord)p
粘贴 p(aste)P
粘贴在当前位置之前限于篇幅,在这里我仅介绍下我非常常用的几个操作。
因为VIM所有的操作都是原子化的,所以把这些操作程序化就非常简单了:
5w
相当于按五次w
键;6j
下移6行,相当于按六次j;3J
大写J,本来是将下一行与当前行合并,加上数量,就是重复操作3次;6dw
和d6w
结果是一样,就是删除6个word;di"
光标在""之间,则删除""之间的内容yi(
光标在()之间,则复制()之间的内容vi[
光标在[]之间,则选中[]之间的内容dtx
删除字符直到遇见光标之后的第一个x
字符ytx
复制字符直到遇见光标之后的第一个x
字符ma
将当前位置标记为a,26个字母均可做标记,mb
、mc
等等;'a
跳转到a标记的位置;qa
将之后的所有键盘操作录制下来,直到再次在命令模式按下q
,并存储在a
中;@a
执行刚刚记录在a
里面的键盘操作;@@
执行上一次的macro操作;VIM的基本操作,可以挖掘的东西非常多,不仅仅需要记忆,更需要自己去探索总结,熟练之后,效率会大幅度提升。后面会给出一些参考链接。
终于到这篇Blog我最想讨论的部分了。VIM的强大不仅仅体现在操作的高效率,更有强大而充沛的插件做支援,插件丰富了之后,就面临查找和管理的问题。
在遇见Vundle之前,我用Pathogen管理插件。Pathogen还算方便,只需要把相应插件,放在bundle
目录下即可,不需要再像以前那样逐个放置单独的文件到相应目录,大大节省了劳动力,管理起来也一目了然,觉得还不错,至少比vimball那种需要执行命令安装的方式好一些。
我真希望我早些遇见Vundle。Vundle受到Pathogen和Vimball的启发,于是有了现在的模样。Vundle的逻辑是这样的:
Bundle plugin_name
;完美的世界!
Vundle的安装很简单:
git clone http://github.com/gmarik/vundle.git ~/.vim/bundle/vundle
然后写配置文件.vimrc
:
1. `set nocompatible " be iMproved` 2. `filetype off " required!` 3. `` 4. `set rtp+=~/.vim/bundle/vundle/` 5. `call vundle#rc()` 6. `` 7. `" let Vundle manage Vundle` 8. `" required!` 9. `Bundle 'gmarik/vundle'` 10. `` 11. `" vim-scripts repos` 12. `Bundle 'vim-plugin-foo'` 13. `Bundle 'vim-plugin-bar'` 14. `` 15. `filetype plugin indent on " required!`
其中Bundle
后面的内容,就是插件的名字,插件维护在Vim-Script.org。
然后,打开VIM之后,可以输入以下命令:
1. `"安装插件:` 2. `:BundleInstall` 3. `` 4. `"更新插件:` 5. `:BundleInstall!` 6. `` 7. `"卸载不在列表中的插件:` 8. `:BundleClean`
现在大部分的插件都已经从Vim.org迁移到了Vim-Script.org,而且很多作者也认领了自己的插件,直接在这个Github的项目下更新,一个比Vim.org更科学更有效的生态环境,就这样完美的形成了。
在此非常严重的感谢vim-scripts.org的创建者Scott Bronson,和Vundle的作者gmarik。他们的创新和分享精神,让这个世界又美好了一些。
也感谢业界良心Github。Vim-Scripts.org整站就是用Github Pages建立维护的,对于个人来说,这是很好的选择,有兴趣的同学可以参看我之前的博客:使用Github Pages建独立博客。
有了Vundle,再装插件就是件享受的事情了。我常用的插件有:
1. `#相较于Command-T等查找文件的插件,ctrlp.vim最大的好处在于没有依赖,干净利落` 2. `Bundle 'ctrlp.vim'` 3. `` 4. `#在输入(),""等需要配对的符号时,自动帮你补全剩余半个` 5. `Bundle 'AutoClose'` 6. `` 7. `#神级插件,ZenCoding可以让你以一种神奇而无比爽快的感觉写HTML、CSS` 8. `Bundle 'ZenCoding.vim'` 9. `` 10. `#在()、""、甚至HTML标签之间快速跳转;` 11. `Bundle 'matchit.zip'` 12. `` 13. `#显示行末的空格;` 14. `Bundle 'ShowTrailingWhitespace'` 15. `` 16. `#JS代码格式化插件;` 17. `Bundle '_jsbeautify'` 18. `` 19. `#用全新的方式在文档中高效的移动光标,革命性的突破` 20. `Bundle 'EasyMotion'` 21. `` 22. `#自动识别文件编码;` 23. `Bundle 'FencView.vim'` 24. `` 25. `#必不可少,在VIM的编辑窗口树状显示文件目录` 26. `Bundle 'The-NERD-tree'` 27. `` 28. `#NERD出品的快速给代码加注释插件,选中,`ctrl+h`即可注释多种语言代码;` 29. `Bundle 'The-NERD-Commenter'` 30. `` 31. `#解放生产力的神器,简单配置,就可以按照自己的风格快速输入大段代码。` 32. `Bundle 'UltiSnips'` 33. `` 34. `#让代码更加易于纵向排版,以=或,符号对齐` 35. `Bundle 'Tabular'` 36. `` 37. `#迄今位置最好的自动VIM自动补全插件了吧` 38. `#Vundle的这个写法,是直接取该插件在Github上的repo` 39. `Bundle 'Valloric/YouCompleteMe'`
以上插件可以在vim-script.org找到源码和文档,ZenCoding和EasyMotion演示点链接,你会心动的。
因为配置不断在更新,所以放上我的配置的链接:.vimrc配置
VIM在一开始会觉得非常不习惯,一定要坚持下去,收获的会更多,不仅仅是在装大侠方面的哦~
关于VIM的使用,这篇博客仅仅介绍了很小的一部分,网络上还有大量朋友总结的心得,常学常有收获: