看了一堆参考,还是乱七八糟,虽然自己已经捋顺了,但是使用还是不顺手,各种快捷键不能用,于是发现了这个,四年前发的,真心觉得,不错,按这个来一遍
强烈推荐:
http://ju.outofmemory.cn/entry/49172
安装插件管理工具 Vundle
git clone https://github.com/VundleVim/Vundle.vim.git ~/.vim/bundle/Vundle.vim
在.vimrc文件的开头添加以下代码:
set rtp+=~/.vim/bundle/Vundle.vim
call vundle#begin()
" 让vundle管理插件版本,必须
Plugin 'VundleVim/Vundle.vim'
" 以下范例用来支持不同格式的插件安装.
" 请将安装插件的命令放在vundle#begin和vundle#end之间.
" Github上的插件
" 格式为 Plugin '用户名/插件仓库名'
" let Vundle manage Vundle
" required!
Plugin 'gmarik/vundle'
Plugin 'cespare/vim-golang'
Plugin 'Blackrush/vim-gocode'
Plugin 'alvan/vim-closetag'
call vundle#end() " 必须
filetype plugin indent on
syntax on
set backspace=indent,eol,start
set autowrite
...........................................................
Install Plugins:
Launch vim and run :PluginInstall
To install from command line: vim +PluginInstall +qall
..............................................................
自动添加/移除import:goimports
安装步骤
go get github.com/bradfitz/goimports
- 在.vimrc里添加:
Bundle 'cespare/vim-golang'
。这条命令会安装cespare/vim-golang的vim插件。这是Go官方vim插件的修改版,支持goimports。 - 重新开启vim,命令模式下执行
:BunduleInstall
。该命令会让Vundle根据.vimrc设定,自动安装缺少的插件。这条命令下面会经常用到。 - (可选)在.vimrc里添加:
autocmd BufWritePre *.go :Fmt
。这条语句可以让任何Go文件保存前,调用goimports对该文件排版并插入/删除相应的import
语句。
使用方法
在对一个Go文件进行编辑后,在命令模式下输入:Fmt
,goimports会在后台被自动调用,对当前编辑的文件排版,并在文件中插入/删除相应的import
语句。
局限
- goimports目前只能添加标准库中的包,如果你使用了非标准库中的函数,你还是要自己手动写好
import
语句。 - 如果你的代码编辑到一半,里面还有一些括号匹配之类的问题。goimports会报错。不过这个报错倒是可以提醒用户代码存在问题。
自动跳转
在调用一个函数,或者使用一个结构体的时候,可能想去跳转到函数定义的地方,看看它的代码是什么。这个功能在阅读别人代码的时候非常有用。安装godef和相应插件,就可以实现这个功能
安装步骤
go get code.google.com/p/rog-go/exp/cmd/godef
- 在.vimrc里添加:
Bundle 'dgryski/vim-godef'
- 重新开启vim,命令模式下执行
:BunduleInstall
。
使用方法
打开一个Go代码文件,把光标移到一个函数上,在命令模式下输入gd
。vim会显示这个函数的定义。详细配置参见godef。
自动补全
啥也不说了。几乎所有的Gopher都应该知道gocode吧。之所以把这么重要的功能放在这么靠后,纯粹是因为它太有名,我都不想说了。
安装步骤
go get github.com/nsf/gocode
- 在.vimrc里添加:
Bundle 'Blackrush/vim-gocode'
- 重新开启vim,命令模式下执行
:BunduleInstall
。
使用方法
写一个hello world,在输入fmt.
之后按
,你会看到显示出fmt
包下面的各个函数,而且会在上面出现一个小窗口,显示出各个函数的声明。当然,这个快捷键是可以设置的。
局限
你必须要先import
,然后才能在相应的包里搜索。把goimports和gocode一起用就看出尴尬了:你输入完fmt.
,本来想要gocode补全,但是如果你没有import fmt
,你就没法补全。这时候你想起了goimports,但是在输入完整的函数名之前,你又没法用goimports自动添加import
语句。所以,你要么输入fmt.Printf()
,然后让goimports添加import语句,接着用gocode自动补全;要么你就老老实实跑到文件开头自己添加import语句然后自动补全。反正你得先自己手动干一样。
Tagbar
很多IDE都可以在代码旁边显示当前文件包含哪些函数定义,结构体定义等等。gotags配合tagbar就可以实现这个功能
go get github.com/jstemmer/gotags
-
添加以下内容到.vimrc:
Bundle 'majutsushi/tagbar' nmap
:TagbarToggle let g:tagbar_type_go = { \ 'ctagstype' : 'go', \ 'kinds' : [ \ 'p:package', \ 'i:imports:1', \ 'c:constants', \ 'v:variables', \ 't:types', \ 'n:interfaces', \ 'w:fields', \ 'e:embedded', \ 'm:methods', \ 'r:constructor', \ 'f:functions' \ ], \ 'sro' : '.', \ 'kind2scope' : { \ 't' : 'ctype', \ 'n' : 'ntype' \ }, \ 'scope2kind' : { \ 'ctype' : 't', \ 'ntype' : 'n' \ }, \ 'ctagsbin' : 'gotags', \ 'ctagsargs' : '-sort -silent' \ } 重新开启vim,命令模式下执行
:BunduleInstall
。
使用方法
编写代码的时候,在命令模式下按
配置括号引号自动补全
vim .vimrc
inoremap ' ''
inoremap " ""
inoremap ( ()
inoremap [ []
inoremap { {
编写代码的时候,在命令模式下按
,你就会看到右边出现了当前文件下的函数名,结构体名等等。把光标放在右边窗口上的相应tag上,按回车可以快速跳到相应位置。再按
会关闭tag窗口。