文章目錄
- 修改_vimrc後自動生效
- 使vim中文化
- 設定字型
- 為編輯PHP代碼進行基本設定
- 設定喜歡的色彩配置
- 更多有用的編輯設定
- 用NERDTree實現目錄導航
- 用taglist實現代碼導航
作者:廖宇雷
雖然vim本質上只是一個編輯器。但只要配合一些適當的外掛程式,vim也能變成一個全功能的IDE。筆者使用vim已經有挺長一段時間了,經過反覆的實驗,配置了一個高效的PHP開發環境,實為居家旅行、謀財害命、殺人越貨必備之良品。
安裝vim
鑒於大多數讀者都是使用Windows環境,所以本文就以Windows作為運行環境。不過由於vim出色的跨平台特性,設定檔只需簡單修改就可以在Linux版本的vim中使用。
目前vim的最新版本是7.2,如果沒有特別原因建議安裝最新的版本。
:http://www.vim.org/download.php#pc
下載檔案:ftp://ftp.vim.org/pub/vim/pc/gvim72.exe
安裝時不要裝到帶有空格、中文的目錄中,其他保持預設即可。筆者的安裝目錄是c:"apps"office"vim,後文也以此為準。為了敘述方便,筆者用$VIM來表示vim的安裝目錄。例如您的vim安裝在d:"vim"中,那$VIM就代表d:"vim"。
開始配置vim
我們對vim的配置分為幾個步驟。
修改_vimrc後自動生效
開啟$VIM目錄,可以看到其中有一個_vimrc檔案,用vim開啟此檔案,刪除所有內容後,在最後插入兩行:
" autoload _vimrc
autocmd! bufwritepost _vimrc source %
上述命令讓我們通過vim編輯_vimrc檔案並儲存時,可以自動載入_vimrc檔案,使得我們對vim的定製可以立即生效(無需重啟vim)。
使vim中文化
在_vimrc頂部增加下列文本:
" disable VI's compatible mode..
set nocompatible
" set encoding=utf-8
set fileencodings=ucs-bom,utf-8,gbk,default,latin1
" use chinese help
set helplang=cn
上述代碼的作用是禁用vi相容模式(原始的vi功能太少了,沒必要考慮相容)、按照utf-8、gbk的順序來檢測檔案編碼,並設定協助為中文。不過設定set helplang=cn並不能馬上看到中文協助,我們還得下載中文協助檔案。
:http://vimcdoc.sourceforge.net/
下載檔案:vimcdoc-1.6.0.tar.gz
得到中文協助檔案壓縮包後,將壓縮包中doc子目錄的所有檔案複製到$VIM"vimfiles"doc目錄中。此時再輸入:help命令就可以看到中文協助了。
中文協助還是7.1版的,不過不影響我們使用。
設定字型
選擇vim菜單的“編輯”->“選擇字型”,就可以為vim指定喜歡的顯示字型了。筆者使用的是Consolas字型,大小設定為9pt。這個設定顯示代碼非常漂亮,不過中文就有點變形了。
設定好後,輸入命令:set guifont可以查看到當前的字型設定,將該設定寫入_vimrc檔案。
"set gui options
if has("gui_running")
set guifont=Consolas:h9
endif
上述代碼中的if … endif是一個條件判斷結構。指示只有當我們使用圖形介面版的vim時才設定字型。
為編輯PHP代碼進行基本設定
現在用vim開啟.php檔案看上去是很難看的,別說代碼高亮,連行號都沒有顯示。所以還要給_vimrc添加以下內容:
" Enable syntax highlight
syntax enable
" Show line number
set nu
" show matching bracets
set showmatch
" Basic editing options
set expandtab
set shiftwidth=2
au FileType html,python,vim,javascript setl shiftwidth=2
au FileType html,python,vim,javascript setl tabstop=2
au FileType java,php setl shiftwidth=4
au FileType java,php setl tabstop=4
set smarttab
set lbr
set tw=0
"Auto indent
set ai
" Smart indet
set si
" C-style indeting
set cindent
" Wrap lines
set wrap
上述設定啟用了格式化高亮、行號顯示,以及括弧匹配、自動縮排等編輯功能,對於大多數情況都可以獲得理想的編輯體驗。不過此時對.php檔案的支援還不完善,需要下載專門的php外掛程式。
:http://www.vim.org/scripts/script.php?script_id=1571
下載檔案:php.tar.gz
將其中的php.vim複製到$VIM"vimfiles"syntax目錄中即可。
設定喜歡的色彩配置
預設的色彩配置相信沒幾個人會喜歡,可以通過下面的網址查看色彩配置並下載(有幾百個哦)。
下載網址:http://www.cs.cmu.edu/~maverick/VimColorSchemeTest/index-c.html
這個網址列出了300多個色彩配置以及實際的顯示效果,點擊方案名稱即可下載到一個.vim檔案。將該檔案放入$VIM"vimfiles"colors目錄,然後在_vimrc中添加:
" set color schema
colorscheme oceandeep
這兩行代碼需要加到if has("gui_running") … endif代碼塊中,例如:
if has("gui_running")
set guifont=Consolas:h9
" set color schema
colorscheme oceandeep
endif
設定後顯示效果就漂亮多了:-)
更多有用的編輯設定
雖然不是專門針對編輯.php檔案的設定,但這些選項可以讓vim更好用,所以建議加上:
" Sets how many lines of history VIM har to remember
set history=400
" Set to auto read when a file is changed from the outside
set autoread
" Have the mouse enabled all the time:
set mouse=a
" Do not redraw, when running macros.. lazyredraw
set lz
" set 7 lines to the curors - when moving vertical..
set so=7
" The commandbar is 2 high
set cmdheight=2
" Change buffer - without saving
set hid
" Ignore case when searching
" set ignorecase
set incsearch
" Set magic on
set magic
" No sound on errors.
set noerrorbells
set novisualbell
set t_vb=
" How many tenths of a second to blink
set mat=4
" Highlight search things
set hlsearch
" Turn backup off
set nobackup
set nowb
set noswapfile
" smart backspace
set backspace=start,indent,eol
" switch buffers with Tab
map <C-Tab> :bn<CR>
map <S-Tab> :bp<CR>
經過一番改造,我們的vim已經可以很順手的編輯.php檔案了。不過要打造php開發環境還有很多工作要做呢。
打造PHP IDE
IDE左側是目錄導航,中間是編輯地區,而右側則是方法列表,用於在已經開啟的檔案中快速跳轉。在編輯地區按下CTRL+X鍵,還會顯示已開啟檔案的列表。
其他諸如自動補全、代碼模板等功能,都應有盡有。看過了漂亮的,我們就來一步步打造PHP IDE吧。
用NERDTree實現目錄導航
在進行PHP應用開發時,同時編輯多個檔案是很正常的事情。所以必須有一個方便的目錄導航工具,以便在目錄結構間快速切換,找到需要編輯的檔案。
vim中提供該類功能的外掛程式很多,比較知名的有project、winmanager等。但筆者個人認為最好用的還是The NERD Tree這個外掛程式。NERDTree不但可以顯示完整的分類樹結構,還可以將任何一個目錄設定為根目錄。並且提供了目錄導航的書籤功能,可謂非常方便。
:http://www.vim.org/scripts/script.php?script_id=1658
下載檔案:NERD_tree.zip
解壓縮時,要把壓縮包中的目錄結構完整的解壓縮到$VIM"vimfiles目錄中。完成後,應該分別找到$VIM"vimfiles"doc"NERD_tree.txt檔案和$VIM"vimfiles"plugin"NERD_tree.vim檔案。然後在vim中輸入命令:helptags $VIM"vimfiles"doc,將NERDTree的協助文檔添加到vim中。
最後在_vimrc添加如下內容:
" NERDTree
map <F10> :NERDTreeToggle<CR>
重啟vim後,按下F10鍵,就可以在左側看到一個分類樹了。在分類樹視窗中按下?鍵可以查看詳細的協助資訊。
最常用的操作鍵有:
按鍵 |
作用 |
C(大寫C鍵) |
將游標所在目錄設定為根目錄 |
u(小寫u鍵) |
轉到上一級目錄 |
o(小寫o鍵,不是“零”) |
展開(或摺疊)游標所在目錄的子目錄。如果游標所在位置是一個檔案,則在編輯視窗中開啟該檔案 |
此外在分類樹視窗中輸入目錄:Bookmark收藏名還可以將游標所在目錄添加到收藏夾中。下次使用:BookmarkToRoot收藏名可以直接轉到該目錄,並且以該目錄作為根目錄。更多命令可以參考NERDTree的協助文檔。
用taglist實現代碼導航
解決了目錄和檔案導航問題,我們還要為代碼之間的跳轉提供輔助手段,taglist就是這樣一個外掛程式。taglist可以列出已開啟檔案中定義的類、函數、常量,甚至變數。
:http://www.vim.org/scripts/script.php?script_id=273
下載檔案:taglist_45.zip
壓縮包需要完整解壓縮到$VIM"vimfiles目錄,並且用:helptags $VIM"vimfiles"doc命令索引taglist外掛程式的協助文檔。taglist外掛程式需要依賴ctags程式才能工作。目前常用的ctags版本是Exuberant Ctags。
:http://ctags.sourceforge.net/
下載檔案:ec57w32.zip
只需要把壓縮包中的ctags.exe複製到$VIM"vim72目錄中即可。ctags.exe應該和gvim.exe在一個目錄。
最後在_vimrc添加下列內容,設定好taglist外掛程式:
"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""
" => Plugin configuration
"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""
" taglist
let Tlist_Auto_Highlight_Tag = 1
let Tlist_Auto_Open = 1
let Tlist_Auto_Update = 1
let Tlist_Close_On_Select = 0
let Tlist_Compact_Format = 0
let Tlist_Display_Prototype = 0
let Tlist_Display_Tag_Scope = 1
let Tlist_Enable_Fold_Column = 0
let Tlist_Exit_OnlyWindow = 0
let Tlist_File_Fold_Auto_Close = 0
let Tlist_GainFocus_On_ToggleOpen = 1
let Tlist_Hightlight_Tag_On_BufEnter = 1
let Tlist_Inc_Winwidth = 0
let Tlist_Max_Submenu_Items = 1
let Tlist_Max_Tag_Length = 30
let Tlist_Process_File_Always = 0
let Tlist_Show_Menu = 0
let Tlist_Show_One_File = 0
let Tlist_Sort_Type = "order"
let Tlist_Use_Horiz_Window = 0
let Tlist_Use_Right_Window = 1
let Tlist_WinWidth = 40
let tlist_php_settings = 'php;c:class;i:interfaces;d:constant;f:function'
這裡的設定是筆者個人習慣的設定,大家在熟悉taglist的具體設定之前可以先嘗試一下。