将vim打造成IDE开发环境

前端之家收集整理的这篇文章主要介绍了将vim打造成IDE开发环境前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

(本文转载自 http://www.cnblogs.com/coolworld/p/5602610.html)


将vim打造成IDE开发环境

本文主要介绍将vim打造成IDE开发环境,如代码补全,高亮显示函数跳转函数自动注释等

首先介绍2款VIM插件管理器:Vbundle,Pathogen

本文中的vim插件,都可以通过这2款插件管理软件进行安装。具体使用方法,请参考官方说明
下面主要介绍通过手动安装的方式,安装VIM插件

一.高亮显示

具体请参考vim配置说明

二.代码自动补全插件neocomplete

使用该插件,需要vim+lua支持,具体配置方法请参考lua安装

neocomplete安装,以下是github地址

https://github.com/Shougo/neocomplete

步骤1:下载插件

gitclonehttps://github.com/Shougo/neocomplete

步骤2:安插neocomplete
将下载的源码复制到vim目录

cdneocomplete
cp-rautoloaddocplugin/usr/share/vim/vim74/

步骤3:配置vimrc,使其支持自动补全
neocomplete配置,在/etc/vimrc (/usr/share/vim/vimrc)中加入如下配置

"Note:Thisoptionmustsetitin.vimrc(_vimrc).NOTIN.gvimrc(_gvimrc)!"DisableAutoComplPop.
letg:acp_enableAtStartup=0
"Useneocomplete.
letg:neocomplete#enable_at_startup=1"Usesmartcase.
letg:neocomplete#enable_smart_case=1
"SetminimumSyntaxkeywordlength.
letg:neocomplete#sources#Syntax#min_keyword_length=3letg:neocomplete#lock_buffer_name_pattern='\*ku\*'"Definedictionary.
letg:neocomplete#sources#dictionary#dictionaries={
\'default':'',\'vimshell':$HOME.'/.vimshell_hist',\'scheme':$HOME.'/.gosh_completions'
\}

"Definekeyword.if!exists('g:neocomplete#keyword_patterns')
letg:neocomplete#keyword_patterns={}
endif
letg:neocomplete#keyword_patterns['default']='\h\w*'"Pluginkey-mappings.
inoremap<expr><C-g>neocomplete#undo_completion()
inoremap<expr><C-l>neocomplete#complete_common_string()

"Recommendedkey-mappings."<CR>:closepopupandsaveindent.
inoremap<silent><CR><C-r>=<SID>my_cr_function()<CR>
function!s:my_cr_function()
return(pumvisible()?"\<C-y>":"")."\<CR>"
"Fornoinserting<CR>key."returnpumvisible()?"\<C-y>":"\<CR>"
endfunction
"<TAB>:completion.
inoremap<expr><TAB>pumvisible()?"\<C-n>":"\<TAB>""<C-h>,<BS>:closepopupanddeletebackwordchar.
inoremap<expr><C-h>neocomplete#smart_close_popup()."\<C-h>"
inoremap<expr><BS>neocomplete#smart_close_popup()."\<C-h>"
"Closepopupby<Space>."inoremap<expr><Space>pumvisible()?"\<C-y>":"\<Space>"

"AutoComplPoplikebehavior."letg:neocomplete#enable_auto_select=1

"Shelllikebehavior(notrecommended)."setcompleteopt+=longest
"letg:neocomplete#enable_auto_select=1"letg:neocomplete#disable_auto_complete=1
"inoremap<expr><TAB>pumvisible()?"\<Down>":"\<C-x>\<C-u>""Enableomnicompletion.
autocmdFileTypecsssetlocalomnifunc=csscomplete#CompleteCSS
autocmdFileTypehtml,markdownsetlocalomnifunc=htmlcomplete#CompleteTags
autocmdFileTypejavascriptsetlocalomnifunc=javascriptcomplete#CompleteJS
autocmdFileTypepythonsetlocalomnifunc=pythoncomplete#Complete
autocmdFileTypexmlsetlocalomnifunc=xmlcomplete#CompleteTags

"Enableheavyomnicompletion.if!exists('g:neocomplete#sources#omni#input_patterns')
letg:neocomplete#sources#omni#input_patterns={}
endif"letg:neocomplete#sources#omni#input_patterns.PHP='[^.\t]->\h\w*\|\h\w*::'
"letg:neocomplete#sources#omni#input_patterns.c='[^.[:digit:]*\t]\%(\.\|->\)'"letg:neocomplete#sources#omni#input_patterns.cpp='[^.[:digit:]*\t]\%(\.\|->\)\|\h\w*::'

"Forperlomni.vimsetting."https://github.com/c9s/perlomni.vim
letg:neocomplete#sources#omni#input_patterns.perl='\h\w*->\h\w*\|\h\w*::'

步骤4:PHP自动补全配置

经过以上配置,默认情况下已经支持大多数语言的代码补全
官方已经禁用了PHP和ruby的代码补全,因为运行效率太慢
要使用PHP补全,参考https://github.com/shawncplus/PHPcomplete.vim说明

Q:IwanttousePHPomnicompletion.A:
Note:YoushouldusethisomnicompletionforPHP.
https://github.com/shawncplus/PHPcomplete.vim>letg:neocomplete#sources#omni#input_patterns.PHP=
\'\h\w*\|[^.\t]->\%(\h\w*\)\?\|\h\w*::\%(\h\w*\)\?'<

在这里,直接在vimrc中加入如下配置,就可以PHP自动补全了

letg:neocomplete#sources#omni#input_patterns.PHP=
\'\h\w*\|[^.\t]->\%(\h\w*\)\?\|\h\w*::\%(\h\w*\)\?'

如果要使用neocomplete推荐的PHP补全,https://github.com/shawncplus/phpcomplete.vim,请参考如下配置

需要安装Vbundle,它是一个vim软件集,且是一个vim插件管理器

https://github.com/VundleVim/Vundle.vim
步骤1
在vim路径,/usr/share/vim/vim74/下建立bundle目录
cd~/.vim/bundle
gitclonegit://github.com/shawncplus/PHPcomplete.vim.git

步骤2:
gitclonehttps://github.com/VundleVim/Vundle.vim.git

在vimrc最开始加入如下配置setnocompatible"beiMproved,required
filetypeoff"required"settheruntimepathtoincludeVundleandinitialize
setrtp+=~/.vim/bundle/Vundle.vim
callvundle#begin()
"alternatively,passapathwhereVundleshouldinstallplugins"callvundle#begin('~/some/path/here')

"letVundlemanageVundle,requiredPlugin'VundleVim/Vundle.vim'"Thefollowingareexamplesofdifferentformatssupported.
"KeepPlugincommandsbetweenvundle#begin/end."pluginonGitHubrepo
Plugin'tpope/vim-fugitive'
"pluginfromhttp://vim-scripts.org/vim/scripts.htmlPlugin'L9'"GitpluginnothostedonGitHub
Plugin'git://git.wincent.com/command-t.git'
"gitreposonyourlocalmachine(i.e.whenworkingonyourownplugin)Plugin'file:///home/gmarik/path/to/plugin'"Thesparkupvimscriptisinasubdirectoryofthisrepocalledvim.
"Passthepathtosettheruntimepathproperly.Plugin'rstacruz/sparkup',{'rtp':'vim/'}"InstallL9andavoidaNamingconflictifyou'vealreadyinstalleda
"differentversionsomewhereelse.Plugin'ascenator/L9',{'name':'newL9'}"AllofyourPluginsmustbeaddedbeforethefollowingline
callvundle#end()"requiredfiletypepluginindenton"required
"Toignorepluginindentchanges,insteaduse:"filetypepluginon
""Briefhelp
":PluginList-listsconfiguredplugins":PluginInstall-installsplugins;append`!`toupdateorjust:PluginUpdate
":PluginSearchfoo-searchesforfoo;append`!`torefreshlocalcache":PluginClean-confirmsremovalofunusedplugins;append`!`toauto-approveremoval
""see:hvundleformoredetailsorwikiforFAQ
"Putyournon-Pluginstuffafterthisline

输入如下命令运行安装插件
:PluginInstall
或者
sh执行vim+PluginInstall+qall

.vimrc加入如下配置
Plugin'shawncplus/PHPcomplete.vim'Sourceyour.vimrcwith:so%orotherwisereloadyourvim
Runthe:PluginInstallcommmand

三.函数,文件自动注释插件 DoxygenToolkit.vim

http://www.vim.org/scripts/script.PHP?script_id=987https://github.com/vim-scripts/DoxygenToolkit.vim安装插件
Copytoyour'~/.vim/plugin'directory
cp-rplugin/usr/shar/vim/vim74/letg:DoxygenToolkit_commentType="PHP"letg:DoxygenToolkit_authorName="coolbaby"lets:licenseTag="Copyright(C)\<enter>"lets:licenseTag=s:licenseTag."Forfree\<enter>"lets:licenseTag=s:licenseTag."Allrightreserved\<enter>"letg:DoxygenToolkit_licenseTag=s:licenseTagletg:DoxygenToolkit_briefTag_funcName="yes"letg:doxygen_enhanced_color=1letg:DoxygenToolkit_briefTag_pre="@descfunction"letg:DoxygenToolkit_paramTag_pre="@params[type]"letg:DoxygenToolkit_returnTag="@return""letg:DoxygenToolkit_blockHeader="--------------------------------------------------------------------------"
"letg:DoxygenToolkit_blockFooter="----------------------------------------------------------------------------""letg:DoxygenToolkit_authorName="MathiasLorente"
"letg:DoxygenToolkit_licenseTag="Myownlicense"

doxygen使用

注释操作都在vim命令行模式下操作:

1 注释类型(C/C++/// 或者,Python:##和#):
在vim中,默认C++注释为,但是如果你更喜欢使用///,只需要在你的配置文件.
vimrc中添加如下语句:
let g:DoxygenToolkit_commentType="C++"。

2 许可:
在vim中,将光标放在将要写doxygen许可注释的那一行,然后,执行命令:DoxLic。这将会生成许可注释并将光标放置在刚才那一行之后。

3 作者:

在vim中,将光标放在想要添加doxygen作者注释的地方。然后执行命令:DoxAuthor。这将会生成一个框架,如果没有为其设置变量则将光标放置在@author标签之后,或者放在在框架之后。

4 函数/类注释:
在vim中,将光标放置在函数头部那一行(或者函数的返回变量)或者类。然后执行命令:Dox这将生成框架并且将光标放置在@brief标签后

5 忽略代码片段(只有C/C++):
在vim中,如果你想要忽略所有在块中的代码片段,类似: #ifdef DEBUG ... #endif你只需要执行以下命令:DoxUndoc(DEBUG)!

6 组:
在vim中,执行命令:DoxBlock在后面的行中插入一个doxygen块。

四.ctags,标签Taglist

taglist是一个用于显示定位程序中各种符号的插件,例如宏定义、变量名、结构名、函数名这些东西 我们将其称之为符号(symbols),而在taglist中将其称之为tag。

显然,要想将程序文件中的tag显示出来,需要事先了解全部tag的信息,并将其保存在一个文件中,然后去解析对应的tag文件

taglist做的仅仅是将tag文件中的内容解析完后显示在Vim上而已。

tag扫描以及数 据文件生成则是由ctags(Exuberant Ctags)这一工具完成的

所以在使用taglist之前,你的电脑需要装有ctags。

1)、vim插件tags安装与配置

ctags可以建立源码树的标签索引(标签就是一个标识符被定义的地方,如函数定义),使程序员在编程时能迅速定位函数、变量、宏定义等位置去查看原形

Ctags工具是用来遍历源代码文件生成tags文件,这些tags文件能被编辑器或其它工具用来快速查找定位源代码中的符号(tag/symbol),如变量名,函数名等。比如,tags文件就是Taglist和OmniCppComplete工作的基础。

以下是在centos6.7下ctags的下载安装和配置过程:

参考资料

https://github.com/shawncplus/PHPcomplete.vim/wiki/Patched-ctagshttp://blog.csdn.net/duguteng/article/details/7412652

ctags相关网站

http://ctags.sourceforge.net/当前的PHP支持ctags发布(5.8)不支持当前的PHP版本的新功能名称空间、特征或旧功能接口。
有一个改进版的https://ctags.io/改进版ctags源码下载https://github.com/shawncplus/PHPcomplete.vim/raw/master/misc/ctags-5.8_better_PHP_parser.tar.gz

ctags安装

wget"https://github.com/shawncplus/PHPcomplete.vim/raw/master/misc/ctags-5.8_better_PHP_parser.tar.gz"-Octags-5.8_better_PHP_parser.tar.gz
tarxvfctags-5.8_better_PHP_parser.tar.gz
./configuremakemakeinstall

运行
ctags--version将会看到ExuberantCtagsDevelopment表示安装成功

使用ctags

cd/path/to/your/projects/root
运行
ctags-R--fields=+aimS--languages=PHP
参数说明

-a
Access(orexport)ofclassmembers;Addstheaccessfieldlike:access:public

-i
Inheritanceinformation;Addstheinheritsfieldlike:inherits:RuntimeException,ExceptionInterface

-m
Implementationinformation;Addstheimplementationfieldlike:implementation:abstract

-S
Signatureofroutine;Addsthesignaturefieldlike:signature:($a,$b)

Theseextrafieldswillshowupinthetagstacklikethis:
使用额外的参数字段将会看到类似下面的堆栈调试信息6Ffhandlevendor/monolog/monolog/src/Monolog/Handler/NullHandler.PHPclass:Monolog\Handler::NullHandleraccess:publicsignature:(array$record)publicfunctionhandle(array$record)

2)、taglist

Taglist用于列出了当前文件中的所有标签(宏,全局变量,函数名等)

安装Taglist

方式1:vim-addonsinstalltaglist
方式2:
官网http://vim-taglist.sourceforge.net/https://sourceforge.net/projects/vim-taglist/files/https://sourceforge.net/projects/vim-taglist/files/vim-taglist/4.6/taglist_46.ziptaglist的github地址https://github.com/vim-scripts/taglist.vim目前最新版本是4.6下载之后解压,拷备目录中的2个目录到vim目录
cp-rdocplugin/usr/share/vim/vim74/

配置Taglist

在Vim配置文件中,可通过"let"语句设定以下变量控制taglist:

Tlist_GainFocus_On_ToggleOpen:为1则使用TlistToggle打开标签列表窗口后会获焦点至于标签列表窗口;为0则taglist打开后焦点仍保持在代码窗口Tlist_Auto_Open:为1则Vim启动后自动打开标签列表窗口Tlist_Close_On_Select:选择标签文件后是否自动关闭标签列表窗口Tlist_Exit_OnlyWindow:Vim当前仅打开标签列表窗口时,是否自动退出VimTlist_Use_SingleClick:是否将默认双击标答打开定义的方式更改为单击后打开标签Tlist_Auto_Highlight_Tag:是否高亮显示当前标签。命令":TlistHighlightTag"也可达到同样效果Tlist_Highlight_Tag_On_BufEnter:默认情况下,Vim打开/切换至一个新的缓冲区/文件后,标签列表窗口会自动将当前代码窗口对应的标签高亮显示。TlistHighlight_Tag_On_BufEnter置为0可禁止以上行为Tlist_Process_File_Always:为1则即使标签列表窗口未打开,taglist仍然会在后台处理vim所打开文件标签Tlist_Auto_Update:打开/禁止taglist在打开新文件修改文件自动更新标签禁止自动更新后,taglist仅在使用:TlistUpdate,:TlistAddFiles,或:TlistAddFilesRecursive命令后更新标签Tlist_File_Fold_Auto_Close:自动关闭标签列表窗口中非激活文件/缓冲区所在文档标签树,仅显示当前缓冲区标签树Tlist_Sort_Type:标签排序依据,可以为"name"(按标签名排序)或"order"(按标签文件中出现的顺序,默认值)Tlist_Use_Horiz_Window:标签列表窗口使用水平分割样式Tlist_Use_Right_Window:标签列表窗口显示在右侧(使用垂直分割样式时)Tlist_WinWidth:设定水平分割时标签列表窗口的宽度Tlist_WinHeight:设定垂直分割时标签列表窗口的高度Tlist_Inc_Winwidth:显示标签列表窗口时允许/禁止扩展Vim窗口宽度Tlist_Compact_Format:减少标签列表窗口中的空白行Tlist_Enable_Fold_Column:是否不显示Vim目录列Tlist_Display_Prototype:是否在标签列表窗口用标签原型替代标签名Tlist_Display_Tag_Scope:在标签名后是否显示标签有效范围Tlist_Show_Menu:在图型界面Vim中,是否以下拉菜单方式显示当前文件中的标签Tlist_Max_Submenu_Item:子菜单项上限值。如子菜单项超出此上限将会被分隔到多个子菜单中。缺省值为25Tlist_Max_Tag_Length:标签菜单标签长度上限

在vim配置文件/home/user/.vimrc中加入如下的配置:

"--Taglistsetting--
"自动更新taglistletTlist_Auto_Update=1"设置taglist宽度
letTlist_WinWidth=40
"因为我们放在环境变量里,所以可以直接执行letTlist_Ctags_Cmd='ctags'"让窗口显示在右边,0的话就是显示在左边
letTlist_Use_Right_Window=1
"让taglist可以同时展示多个文件函数列表letTlist_Show_One_File=0
"非当前文件函数列表折叠隐藏
letTlist_File_Fold_Auto_Close=1
"当taglist是最后一个分割窗口时,自动推出vimletTlist_Exit_OnlyWindow=1"为1则即使标签列表窗口未打开,taglist仍然会在后台处理vim所打开文件标签
letTlist_Process_File_Always=1
letTlist_Inc_Winwidth=0

标签列表窗口快捷键

taglist快捷键:

<CR>:代码窗口跳转标签列表窗口中光标所在标签定义处o:在新建代码窗口中跳转标签列表窗口中光标所在标签定义处P:跳转至上一个窗口的标签处p:代码窗口中内容跳转标签定义处,光标保持在标签列表窗口中t:在Vim新标签窗口中跳转标签定义处。如文件已经在Vim标签窗口中打开,则跳转至此标签窗口
Ctrl-t:在Vim新标签窗口处跳转标签定义处
:显示光标当前所在标签原型。对文件标签显示文件的全路径名,文件类型和标签数量。对标签类型(指如variable/function等类别),显示标签类型和拥有标签数量;对函数/变量等普通标签显示其定义的原型u:更新标签列表窗口中的标签信息s:切换标签排序类型(按名称序或出现顺序)d:移除当前标签所在文件的所有标签x:扩展/收缩标签列表窗口
+:展开折叠节点*
-:折叠结点*
*:展开所有结点
=:折叠所有节点
[[:跳转至上一个文件标签的头部
<Backspace>:跳转至上一个文件标签头部
]]:跳转至下一个文件标签头部
<Tab>:跳转至下一个文件标签头部q:关闭标签列表窗口F1:显示帮助**

taglist命令

taglist在Vim中提供了以下扩展命令:

:TlistAddFiles{files(s)}[file(s)...]添加一或多个指定文件(的标签项)到标签列表窗口中。文件名表达式中可使用通配符(*);如文件名中带有空格,需要使用反斜杠对空格进行转义("\")
:TlistAddFilesRecursive{directory}[{pattern}]遍历指定路径{directory},将与模式{pattern}相匹配的文件加入标签列表窗口。如未指定pattern,则使用缺省值'*'。如路径中包含空格,需使用反斜杠'\'转义("\")
:TlistClose关闭标签列表窗口
:TlistDebug[filename]记录taglist插件的调试信息。如指定了filename,则调试信息将被写入此指定文件(如文件已存在,内容将被覆盖);如未指定filename,则调试信息写入脚本的局部变量中
:TlistLock锁定标签列表,并且不处理新打开的文件
:TlistMessage仅当调试信息写入脚本局部变量时有效,显示记录的调试信息
:TlistOpen打开并跳转标签列表窗口
:TlistSessionSave{filename}将当前打开文件及其标签信息写入指定文件
:TlistSessionLoad{filename}从指定文件载入所保存的会话信息
:TlistShowPrototype[filename][linenumber]显示指定文件中指定代码行或之前的标签的原型。如未指定文件名/行号,则使用当前文件名/当前行号
:TlistShowTag[filename][linenumber]显示指定文件中指定代码行或之前标签名称。如未指定文件名/行号,则使用当前文件名/当前行号
:TlistHighlightTag加亮显示标签窗口中的当前标签
:TlistToggle在打开和关闭状态间切换标签窗口的状态。标签窗口切换至打开状态后仍然光标保持在代码窗口中
:TlistUndebug停止记录taglist插件调试信息
:TlistUnlock解锁标签列表,并处理新打开的文件
:TlistUpdate更新当前缓冲区的标签信息

taglist全局函数

taglist插件为Vim提供了一些全局函数,可供其他插件使用:

Tlist_Update_File_Tags({filename},{filetype})以指定文件类型更新指定文件标签信息。如taglist插件此前未处理过指定文件,则会调用ctags对文件进行分析
Tlist_Get_Tag_Prototype_By_Line([{filename},{linenumber}])获取指定文件中指定行号或之前标签的原型信息。如未指定文件名/行号,则使用当前缓冲区对应文件/当前行号
Tlist_Get_Tagname_By_Line([{filename},{linenumber}])获取指定文件中指定行号或之前标签名称信息。如未指定文件名/行号,则使用当前缓冲区对应文件/当前行号
Tlist_Set_App({appname})设置正在控制taglist的插件名称

使用方法
http://blog.csdn.net/skyflying2012/article/details/8112144参考

在源码目录下,执行ctags -R对各目录递归创建生成tags文件

用Vim打开源码文件,以命令模式执行Tlist,即可启用Taglist插件,可以查看taglist的帮助信息

:TlistToggle可以关闭,打开taglist
使用键映射关闭打开

nnoremap<silent><F8>:TlistToggle<CR>

在Vim中加载代码文件后,可以使用以下命令控制taglist

:TlistOpen打开并将输入焦点至于标签列表窗口:TlistClose关闭标签列表窗口:TlistToggle切换标签列表窗口状态(打开←→关闭),标签列表窗口是否获得焦点取决于其他配置
ctl-w+w或ctl-w+方向键窗口切换(taglist本质上是一个vim分隔窗口,因此可以使用ctl-w系列快捷键对窗口进行切换操作)
使用鼠标单击切换当前窗口,或在标签列表窗口某标签上双击使代码窗口内窗跳转标签定义
标签列表窗口内,当光标停留在某个标签之上时,回车键可切换代码窗口内容标签定义;'o',在分隔窗口中显示;'t',在vim新标签窗口中显示

官方使用手册
http://vim-taglist.sourceforge.net/manual.html

进入vim后用命令":Tlist"打开/关闭taglist窗口
帮助文档
:help taglist.txt

五.代码折叠

折叠用于把缓冲区内某一范围内的文本行显示为屏幕上的一行。就像一张纸,要它缩短
些,可以把它折叠起来:

+------------------------+
|行1|
|行2|
|行3|
|_______________________|
\\
\________________________\
/被折叠的行/
/________________________/
|行12|
|行13|
|行14|
+------------------------+

那些文本仍然在缓冲区内而没有改变。受到折叠影响的只是文本行显示的方式。

折叠的好处是,通过把多行的一节折叠成带有折叠提示的一行,会使你更好地了解对文本
的宏观结构。

折叠方式foldmethod

vim提供以下6种方法来选定折叠方式:

manual手工定义折叠
indent更多的缩进表示更高级别的折叠
expr用表达式来定义折叠
Syntax用语法高亮来定义折叠
diff对没有更改的文本进行折叠
marker对文中的标志折叠

折叠级别foldlevel

'foldlevel' 是个数值选项:数字越大则打开的折叠更多。

当 'foldlevel' 为 0 时,所有的折叠关闭

当 'foldlevel' 为正数时,一些折叠关闭

当 'foldlevel' 很大时,所有的折叠打开。

折叠栏foldcolumn

'foldcolumn' 是个数字,它设定了在窗口的边上表示折叠的栏的宽度。当为0时,没有折叠栏。最大是12。

一个打开的折叠由一栏来表示,顶端是 '-',其下方是 '|'。这栏在折叠结束的地方结束。当折叠嵌套时,嵌套的折叠出现在被包含的折叠右方一个字符位置。

一个关闭的折叠由 '+' 表示。

当折叠栏太窄而不能显示所有折叠时,显示一数字来表示嵌套的级别。

在折叠栏点击鼠标,可以打开和关闭折叠:

点击 '+' 打开在这行的关闭折叠

在任何其他非空字符上点击,关闭这行上的打开折叠

在vim配置文件/home/user/.vimrc中加入如下的配置:

"--foldsettingvim折叠设置--

"用缩进来定义折叠setfoldmethod=indext"启动vim时不要自动折叠代码
setfoldlevel=100
"设置折叠栏宽度setfoldcolumn=5

常用命令

za打开/关闭在光标下的折叠
zA循环地打开/关闭光标下的折叠
zo打开(open)在光标下的折叠
zO循环打开(Open)光标下的折叠
zc关闭(close)在光标下的折叠
zC循环关闭(Close)在光标下的所有折叠
zM关闭所有折叠
zR打开所有的折叠
帮助文档
:helpusr_28.txt
:helpfold.txt

参考资料
http://www.cnblogs.com/zhangsf/archive/2013/06/13/3134409.html

六、vim语法检查插件syntastic

github地址

https://github.com/scrooloose/syntastic

环境需求

需要vim支持autocmd,eval,file_in_path,modify_fname,quickfix,reltime,and user_commands
检查以上vim依赖是否安装,出现+表示满足要求

vim--version|grepautocmd

这个插件是用来做静态语法检查的,支持多语言,比如 Ruby,Python 和 JavaScript 等。实际上这个插件是个接口,背后的语法检查是交给各个语言自己的检查器,Ruby 实际使用ruby -c命令,JavaScript 使用 jshint,jslint 等。

注意安装后jshint需要在系统环境变量中,否则需要指定path:
g:syntastic_jshint_exec
指定jshint的配置文件目录:
g:syntastic_javascript_jshint_conf

最后但并非最不重要的:syntastic不知道如何自己做任何语法检查。为了得到有意义的结果,你需要安装相应的文件外部检查你使用的类型

安装syntastic with Pathogen

1.需要先安装Pathogen

https://github.com/tpope/vim-pathogengitclonehttps://github.com/tpope/vim-pathogencdvim-pathogen
cp-rautoload/usr/share/vim/vim74/

在vimrc中加入配置

executepathogen#infect()

2.安装syntastic

mkdir-p/usr/share/vim/vim74/bundle
cd/usr/share/vim/vim74/bundle
gitclonehttps://github.com/scrooloose/syntastic.git

3.推荐配置syntastic

setstatusline+=%#warningmsg#setstatusline+=%{SyntasticStatuslineFlag()}setstatusline+=%*

letg:syntastic_always_populate_loc_list=1letg:syntastic_auto_loc_list=1letg:syntastic_check_on_open=1letg:syntastic_check_on_wq=0letg:syntastic_error_symbol='err!'letg:syntastic_warning_symbol='!'nmap<A-up>:lprev<cr>nmap<A-down>:lnext<cr>nmap<A-right>:ll<cr>

4.安装PHP语法分析器PHPcs

方式1pearinstallPHP_CodeSniffer
方式2composerglobalrequire"squizlabs/PHP_codesniffer=*"

vim帮助文档:help syntastic

七、目录管理工具NERDtree

安装方式
插件管理器pathogen.vim或者Vundle安装

cd~/.vim/bundle
gitclonehttps://github.com/scrooloose/nerdtree.git

启动vim,自动打开NERDtree

autocmdvimenter*NERDTree

How can I open a NERDTree automatically when vim starts up if no files were specified?

autocmdStdinReadPre*lets:std_in=1autocmdVimEnter*ifargc()==0&&!exists("s:std_in")|NERDTree|endif

映射快捷键

map<C-n>:NERDTreeToggle<CR>

如果只剩下NERDTree最后一个窗口,如何关闭NERDTree

autocmdbufenter*if(winnr("$")==1&&exists("b:NERDTree")&&b:NERDTree.isTabTree())|q|endif

Can I have different highlighting for different file extensions?
不同的扩展名,显示不同的颜色

"NERDTressFilehighlighting
function!NERDTreeHighlightFile(extension,fg,bg,guifg,guibg)
exec'autocmdfiletypenerdtreehighlight'.a:extension.'ctermbg='.a:bg.'ctermfg='.a:fg.'guibg='.a:guibg.'guifg='.a:guifg
exec'autocmdfiletypenerdtreesynmatch'.a:extension.'#^\s\+.*'.a:extension.'$#'endfunction

callNERDTreeHighlightFile('jade','green','none','#151515')callNERDTreeHighlightFile('ini','yellow','#151515')callNERDTreeHighlightFile('md','blue','#3366FF','#151515')callNERDTreeHighlightFile('yml','#151515')callNERDTreeHighlightFile('config','#151515')callNERDTreeHighlightFile('conf','#151515')callNERDTreeHighlightFile('json','#151515')callNERDTreeHighlightFile('html','#151515')callNERDTreeHighlightFile('styl','cyan','#151515')callNERDTreeHighlightFile('css','#151515')callNERDTreeHighlightFile('coffee','Red','red','#151515')callNERDTreeHighlightFile('js','#ffa500','#151515')callNERDTreeHighlightFile('PHP','Magenta','#ff00ff','#151515')

How can I change default arrows?
改变默认的箭头

letg:NERDTreeDirArrowExpandable=''letg:NERDTreeDirArrowCollapsible=''

http://vim.wikia.com/wiki/Understanding_VIMRUNTIME

猜你在找的Bash相关文章