最好用的編輯器之一:Vim-Go環境搭建

本文由Librant發表

如果說在Linux環境下,什麼編輯器最好用,如果我說是VIM,估計會有一大部分人嗤之以鼻,怎麼可能。VIM可能是他用過衆多編輯器最難用的一個。在我司用的是雲虛擬機,說實話吧,這裏吐槽一下,是真的卡,沒開幾個網頁,打開幾個軟件就卡的不要不要的,後來碼代碼的時候,能用Linux機器我就儘量使用Linux環境,如果讀者正好也是一名Gopher的話,那我就強烈建議你使用VIM,Vim-go是當前使用最爲廣泛的用於搭建Golang開發環境的vim插件。好了,廢話不多說,看我搭建好的界面吧。

img圖 Go-Vim界面

看到這個界面,讀者是不是不認識了,這就對了,是不是覺得很炫酷,其實Vim有很多的插件,可以把Vim打造的非常棒,等讀者查閱相關資料,清楚Vim的各種參數的時候,就可以根據自己的喜好,搭建不同風格的Go開發環境啦。So廢話不多說,開整。(建議先看完《跟我學Docker》的第一章部分)

1.1 環境準備

​ 能成功從gitHub拉取代碼,Go編譯器安裝完成之後,就可以在搭建Go-Vim啦。首先是在當前用戶的HOME目錄下創建 .vim 目錄和 .vimrc 文件:

librant@ubuntu:~$ mkdir .vim

librant@ubuntu:~$ touch .vimrc

創建完成之後,進入到 .vim 中,下載插件 Vim 的插件管理器bundle:

librant@ubuntu:~/.vim$ mkdir bundle

然後進入到 bundle 目錄中,安裝Vundle.vim:

librant@ubuntu:~/.vim/bundle$ git clone git clone https://github.com/VundleVim/Vundle.vim.git

下載完成之後,會在當前目錄下生成 Vundle.vim 目錄

同樣進入到 bundle 目錄中,安裝Vim-go:

librant@ubuntu:~/.vim/bundle$ git clone https://github.com/fatih/vim-go.git

下載完成之後,會在當前目錄下生成 vim-go 目錄

1.2 插件安裝

~/(用戶$HOME) 目錄下已經有 .vimrc文件就不需要再創建了。(" 爲註釋部分)。

1.2.1 安裝Vundle.vim

在 .vimrc 文件中添加如下配置:

set nocompatible

filetype off

set rtp+=~/.vim/bundle/Vundle.vim

call vundle#begin()

Plugin 'gmarik/Vundle.vim'

call vundle#end()

filetype plugin indent on

保存後,退出。

1.2.2 安裝Vim-go

繼續編輯 .vimrc文件,在call vundle#begin()和call vundle#end()之間再添加如下配置:

Plugin 'fatih/vim-go'

保存後,重新打開 vim 編輯器,在命令行的模式輸入:PluginInstall

:PluginInstall

執行之後會在左側出現需要安裝的插件列表,右側是.vimrc文件。如圖1-2-2所示:

img圖 1-2-2 Vim插件安裝界面

剛執行時,左下角會出現 Processing的過程,需要稍微等一會兒,這是在下載代碼,安裝完成之後,左下角將出現Done!的單詞,表示已經安裝完成。

1.2.3 安裝 go.tools Binaries

​ Vim-go安裝中需要使用到Go的相關的二進制工具。由於歷史的原因,在google上的工具是無法自行下載安裝的,在gitHub上的工具是可以安裝成功的。

首先打開 .vimrc 文件,切換到命令行模式,執行 GoInstallBinaries 命令自行安裝。

:GoInstallBinaries

等待 Vim-go依賴的工具自動安裝,如果安裝成功後,會在 $GOPATH/bin 目錄下生成。安裝完成後如圖1-2-3所示:

img圖 1-3-2 vim-go依賴的命令文件

由於有些命令文件是無法自動安裝完成,這就需要手動進行安裝啦。首先對比目錄,看缺少哪些命令沒有安裝完成,然後去gitHub上搜索,找到對應的命令源碼之後,使用git clone 下載到本地,然後使用 go install命令進行安裝即可。前面已經講解過如何安裝啦,這裏就不再贅述。

相關工具的gitHub路徑:

golint: https://github.com/golang/lint.git

gocode: https://github.com/nsf/gocode.git

errcheck: https://github.com/kisielk/errcheck.git

gotags: https://github.com/jstemmer/gotags.git

(缺少什麼工具,基本都可以找到的,這裏就不一一列舉了)

1.3 VIM主題顏色

​ Vim的主題顏色保存在 /usr/share/vim/vim80/colors 目錄下保存,如果目錄下沒有的主題,就需要自己進行下載了。下載到此目錄的顏色主題,將可以被所有用戶使用,如果只需要在當前用戶下使用,可以將下載的主題放在 ~/.vim/colors 目錄下即可。個人比較喜歡molokai主題風格,下面就簡單介紹如何下載這個主題吧。

​ 1)在gitHub上搜索 molokai 主題,找到主題的git倉庫 tomasr/molokai

​ 2)進入到 .vim目錄下,使用git clone 下載主題

librant@ubuntu:~/.vim$ git clone https://github.com/tomasr/molokai.git

​ 3)下載完成之後,拷貝 molokai/colors/molokai.vim 文件到 ~/.vim/colors 目錄下

​ 4)配置 .vimrc 文件,在文件中紅添加如下信息:

set t_Co=256

colorscheme molokai

let g:molokai_original = 1

let g:rehash256 = 1

需要配置其他的主題,只需要設置相應的主題名稱。

1.4 其他插件安裝

1.4.1 SirVer/ultisnips

​ UltiSnips是Vim的代碼片段工具,它只是一個引擎,它需要和vim-snippets搭配使用。vim-snippets預定義了幾十種語言常用的代碼模板,位於 ~/.vim/bundle/vim-snippets/UltiSnips/,UltiSnips 有一套自己的代碼模板語法規則。

在 .vimrc中的配置如下:

Plugin 'honza/vim-snippets'

Plugin 'SirVer/ultisnips'

"插入模式下直接通過<C-z>鍵來觸發UltiSnips的代碼塊補全

let g:UltiSnipsExpandTrigger="<C-z>"

"彈出UltiSnips的可用列表,由於不常用, 所以這裏設置成了特殊的<C-i>映射

let g:UltiSnipsListSnippets="<C-i>"

"<C-f>跳轉的到下一個代碼塊可編輯區

let g:UltiSnipsJumpForwardTrigger="<C-f>"

"<C-b>跳轉到上一個代碼塊可編輯區

let g:UltiSnipsJumpBackwardTrigger="<C-b>"

增加位置如Go-vim的位置一致,安裝過程也是類似的。

gitHub的代碼路徑如下所示:

honza/vim-snippets: https://github.com/honza/vim-snippets.git

SirVer/ultisnips: https://github.com/SirVer/ultisnips.git

1.4.2 scrooloose/nerdtree

​ NERDTree的作用就是列出當前路徑的目錄樹,一般IDE都是有的。可以方便的瀏覽項目的總體的目錄結構和創建刪除重命名文件或文件名。

​ 在 .vimrc中的配置如下:

Plugin 'scrooloose/nerdtree'

" 設置NerdTree

map <F7> :NERDTreeMirror<CR>

map <F7> :NERDTreeToggle<CR>

進入到 vim 後可以按 F7 顯示和隱藏 NERDTree區域。

gitHub的代碼路徑如下所示:

scrooloose/nerdtree: https://github.com/scrooloose/nerdtree.git

1.4.3 majutsushi/tagbar

​ tagbar可以將正在編輯的文件生成一個大綱視圖,包含接口/方法/變量等, 可以選中快速跳轉到目標位置, 編輯大文件特別有用。

由於tagbar是基於ctags,需要先安裝ctags:

root@ubuntu:/# apt-get install ctags

​ 在 .vimrc中的配置如下:

"F9觸發,設置寬度爲30

let g:tagbar_width = 30

nmap <F9> :TagbarToggle<CR>

"開啓自動預覽(隨着光標在標籤上的移動,頂部會出現一個實時的預覽窗口)

let g:tagbar_autopreview = 1

"關閉排序,即按標籤本身在文件中的位置排序

let g:tagbar_sort = 0

進入到 vim 後可以按 F9 開啓和關閉tagbar功能 。

gitHub的代碼路徑如下所示:

majutsushi/tagbar: https://github.com/majutsushi/tagbar.git

1.4.4 Raimondi/delimitMate

​ delimitMate是自動補全引號(單引號/雙引號/反引號), 括號(()[]{})的插件。

​ 在 .vimrc中的配置如下:

Plugin 'Raimondi/delimitMate'

gitHub的代碼路徑如下所示:

Raimondi/delimitMate: https://github.com/Raimondi/delimitMate.git

GO語言調試利器——dlv

vim創建程序文件自動添加頭部註釋

附錄:VIM參數設置解析

  1. set nocompatible:不要使用vi的鍵盤模式,而是vim自己的
  2. set number:顯示行號
  3. set showcmd:輸入的命令顯示出來
  4. syntax on:開啓語法高亮
  5. filetype on:檢測文件類型
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章