Vim配置及说明 IDE编程环境

1、基本及字体

对于用惯了Windows下ctrl+s一键保存的人是不是对与vim中在命令行下:w的保存方式很不习惯?

在.vimrc中加入如下配置,你可以使用s一键保存

1. ' s 一键保存
2. func! SaveFile()
3. exec 'w'
4. endfunc
5. map  <leader>s :call SaveFile()<CR>
6. imap <leader>s <ESC>:call SaveFile()<CR>
7. vmap <leader>s <ESC>:call SaveFile()<CR>

安装字体Monaco

默认字体不好看,挑个自己喜欢的,前提是你得先安装好该字体。我喜欢Monaco字体,美观,对中文支持也很好。

下面是找到的安装过程,亲自验证。

首先在https://github.com/cstrap/monaco-font 这个网址下载Monaco字体 使用命令 unzip monaco-font-master解压压缩包 切换到monaco-font-master目录中,修改脚本文件权限chmod +x install-font.sh 执行脚本文件sudo ./install-font.sh
2、插件管理

插件[ gmarik/vundle]

推荐等级:★★★★★

vim 的各插件打包文档中通常也包含doc、plugin子目录,用户将插件打包文档中的对应子目录拷贝至.vim/目录中即可完成安装,但插件一多将混乱不堪,会出现名字冲突,卸载麻烦(有时分不清那个文件对应哪个插件,自己也不清楚到底安装了哪些插件)等问题。

vundle可以帮我们解决这些问题。

通过使用vundle来安装新的插件也及其方便:

可以去GIT,也可以去Vim Scripts查找并选好你想要的插件。 在VIM的配置文件中写一句 Bundle plugin_name; 执行一下Vundle的初始化命令,插件就装好了; 升级和卸载也是同样的简单;

Bundle 支持的格式有三种:

第一种是一个普通的字符串,就是 vim 插件页面里左上角的插件名字,如果插件名有空格,使用 - 替换。

第二种是github帐号/项目名。

第三种就是git repository

具体可查看vbundle的帮助文档。

3、主题风格

一套好的配色方案绝对会影响你的编码效率,vim 内置了 10 多种配色方案供你选择

GUI 下,可以通过菜单(Edit -> Color Scheme)试用不同方案,字符模式下,需要你手工调整配置信息,再重启 vim 查看效果(csExplorer 插件,可在字符模式下不用重启即可查看效果)。 还不满意,可以在VIM Color Scheme Test - C这里选择自己喜欢的配色方案

目前用得最多的是下面三种配色方案:

solarized 推荐等级:★★★★★ molokai 推荐等级:★★★★★ phd 推荐等级:★★★★☆

我的配置如下:

01. ' 主题 solarized
02. Bundle 'altercation/vim-colors-solarized'
03. 'let g:solarized_termcolors=256
04. let g:solarized_termtrans=1
05. let g:solarized_contrast='normal'
06. let g:solarized_visibility='normal'
07. ' 主题 molokai
08. Bundle 'tomasr/molokai'
09. let g:molokai_original = 1
10. ' 配色方案
11. set background=dark
12. set t_Co=256
13. if g:isGUI
14. colorscheme solarized
15. 'colorscheme molokai
16. 'colorscheme phd
17. else
18. 'colorscheme solarized
19. colorscheme molokai
20. 'colorscheme phd
21. endif

其中,不同主题都有暗/亮色系之分,这样三种主题六种风格,久不久换一换,给你不一样的心情

4、窗口设置

编辑器界面展示的应全是代码,不应该有工具条、菜单、滚动条浪费空间的元素,配置如下:

01. if g:isGUI      ' 使用GUI界面时的设置
02. set guioptions+=c        ' 使用字符提示框
03. set guioptions-=m        ' 隐藏菜单栏
04. 'set guioptions-=T        ' 隐藏工具栏
05. set guioptions-=L        ' 隐藏左侧滚动条
06. 'set guioptions-=r        ' 隐藏右侧滚动条
07. set guioptions-=b        ' 隐藏底部滚动条
08. 'set showtabline=0       ' 隐藏Tab栏
09. set cursorline           ' 突出显示当前行
10. endif

我们把 vim 弄成全屏模式。vim 自身无法实现全屏,必须借助第三方工具wmctrl, 一个控制窗口XYZ坐标、窗口尺寸的命令行工具。先自行安装wmctrl(sudo apt-get install wmctrl) ,再在.vimrc中增加如下信息:

1. fun! ToggleFullscreen()     ' 将外部命令 wmctrl 控制窗口最大化的命令行参数封装成一个 vim 的函数
2. call system('wmctrl -ir ' . v:windowid . ' -b toggle,fullscreen')
3. endf
4. map <silent> <F11> :call ToggleFullscreen()<CR>   ' 全屏开/关快捷键
5. autocmd VimEnter * call ToggleFullscreen()  ' 启动 vim 时自动全屏
5、目录树导航

插件:vim-scripts/The-NERD-tree

推荐等级:★★★★★

nerd-tree插件可以查看文件列表,要打开哪个文件,光标选中后回车即可在新 buffer 中打开。

配置如下:

01. '目录文件导航
02. Bundle 'scrooloose/nerdtree'
03. '
04. t                 打开nerdree窗口,在左侧栏显示
05. nmap <leader>nt :NERDTree<CR>
06. let NERDTreeHighlightCursorline=1
07. let NERDTreeIgnore=[ '.pyc$''.pyo$''.obj$''.o$''.so$''.egg$''^.git$''^.svn$''^.hg$' ]
08. let g:netrw_home='~/bak'
09. 'close vim if the only window left open is a NERDTree
10. autocmd bufenter * if (winnr('$') == 1 && exists('b:NERDTreeType') && b:NERDTreeType == 'primary') | q | end
6、标签导航

majutsushi/tagbar

推荐等级:★★★★★

tagbar按作用域归类不同的标签。按名字空间 n_foo、类 Foo 进行归类,在内部有声明、有定义; 显示标签类型。名字空间、类、函数等等; 显示完整函数原型; 图形化显示共有成员(+)、私有成员(-)、保护成员(#);

配置如下:

1. '标签导航,纬度和taglist不同
2. Bundle 'majutsushi/tagbar'
3. nmap <leader>tb :TagbarToggle<CR>  '    b 打开tagbar窗口
4. let g:tagbar_autofocus = 1
7、taglist

vim-scripts/taglist.vim

推荐等级:★★★★☆

在vimrc中配置如下:

01. Bundle 'vim-scripts/taglist.vim'
02. '   l                 打开Taglist/TxtBrowser窗口,在右侧栏显示
03. nmap <leader>tl :Tlist<CR><c-l>
04. ' :Tlist              调用TagList
05. let Tlist_Show_One_File        = 1             ' 只显示当前文件的tags
06. let Tlist_Exit_OnlyWindow      = 1             ' 如果Taglist窗口是最后一个窗口则退出Vim
07. let Tlist_Use_Right_Window     = 1             ' 在右侧窗口中显示
08. let Tlist_File_Fold_Auto_Close = 1             ' 自动折叠
09. 'let Tlist_Sort_Type = 'name'                   ' items in tags sorted by name
8、多文档编辑

插件fholgado/minibufexpl.vim

推荐等级:★★★★★

vim 的多文档编辑涉及三个概念:buffer、window、tab,这三个事物与我们常规理 解意义大相径庭。vim 把加载进内存的文件叫做 buffer,buffer 不一定可见;若要 buffer 要可见,则必须通过 window 作为载体呈现;同个看面上的多个 window 组合成 一个 tab。vim 中每打开一个文件,vim 就对应创建一个 buffer,多个文件就有多个 buffer,但默认你只看得到最后 buffer 对应的 window

vimrc中配置如下:

01. Bundle 'fholgado/minibufexpl.vim'
02. ' 多文件切换,也可使用鼠标双击相应文件名进行切换
03. let g:miniBufExplMapWindowNavVim    = 1
04. let g:miniBufExplMapWindowNavArrows = 1
05. let g:miniBufExplMapCTabSwitchBufs  = 1
06. let g:miniBufExplModSelTarget       = 1
07. '解决FileExplorer窗口变小问题
08. let g:miniBufExplForceSyntaxEnable = 1
09. let g:miniBufExplorerMoreThanOne=2
10. let g:miniBufExplCycleArround=1
11. ' buffer 切换快捷键,默认方向键左右可以切换buffer
12. map <C-Tab> :MBEbn<cr>
13. map <C-S-Tab> :MBEbp<cr>
9、文件搜索

插件:kien/ctrlp.vim

推荐等级:★★★★☆

CtrlP会沿着vim打开的目录一直向上查找类似.git/.svn等这样的项目管理的目录,如果找到则将这个作为项目的根目录 vimrc中配置如下:

01. 'for file search ctrlp, 文件搜索
02. Bundle 'kien/ctrlp.vim'
03. ' 打开ctrlp搜索
04. let g:ctrlp_map = '<leader>ff'
05. let g:ctrlp_cmd = 'CtrlP'
06. ' 相当于mru功能,show recently opened files
07. map <leader>fp :CtrlPMRU<CR>
08. 'set wildignore+=*/tmp/*,*.so,*.swp,*.zip     ' MacOSX/Linux'
09. let g:ctrlp_custom_ignore = {
10. 'dir':  ' [/].(git|hg|svn|rvm)$',
11. 'file'' .(exe|so|dll|zip|tar|tar.gz)$',
12. }
13. ' 'link': 'SOME_BAD_SYMBOLIC_LINKS',
14. let g:ctrlp_working_path_mode=0
15. let g:ctrlp_match_window_bottom=1
16. let g:ctrlp_max_height=15
17. let g:ctrlp_match_window_reversed=0
18. let g:ctrlp_mruf_max=500
19. let g:ctrlp_follow_symlinks=1
10、美化状态栏

插件:Lokaltog/vim-powerline

推荐等级:★★★★☆

状态栏增强展示,通过本插件,增强后的状态栏,不仅界面漂亮多了,而且多 了好些辅助信息(所在函数名、文件编码格式、文件类型)。 vimrc中配置如下:

1. Bundle 'Lokaltog/vim-powerline'
2. 'if want to use fancy,need to add font patch -> git clone git://gist.github.com/1630581.git ~/.fonts/ttf-dejavu-powerline
3. 'let g:Powerline_symbols = 'fancy'
4. let g:Powerline_symbols = 'unicode'
11、括号匹配高亮

插件:kien/rainbow_parentheses.vim

推荐等级:★★★★☆

括号显示增强 vimrc中配置如下:

01. Bundle 'kien/rainbow_parentheses.vim'
02. let g:rbpt_colorpairs = [
03. ['brown',       'RoyalBlue3'],
04. ['Darkblue',    'SeaGreen3'],
05. ['darkgray',    'DarkOrchid3'],
06. ['darkgreen',   'firebrick3'],
07. ['darkcyan',    'RoyalBlue3'],
08. ['darkred',     'SeaGreen3'],
09. ['darkmagenta''DarkOrchid3'],
10. ['brown',       'firebrick3'],
11. ['gray',        'RoyalBlue3'],
12. ['black',       'SeaGreen3'],
13. ['darkmagenta''DarkOrchid3'],
14. ['Darkblue',    'firebrick3'],
15. ['darkgreen',   'RoyalBlue3'],
16. ['darkcyan',    'SeaGreen3'],
17. ['darkred',     'DarkOrchid3'],
18. ['red',         'firebrick3'],
19. ]
20. let g:rbpt_max = 40
21. let g:rbpt_loadcmd_toggle = 0
12、可视化缩进

插件:nathanaelkane/vim-indent-guides

推荐等级:★★★★☆

可视化的方式能将相同缩进的代码关联起来。 显可视化缩进,示对齐线。 vimrc中配置如下:

1. Bundle 'nathanaelkane/vim-indent-guides'
2. let g:indent_guides_enable_on_vim_startup = 0  ' 默认关闭
3. let g:indent_guides_guide_size            = 1  ' 指定对齐线的尺寸
4. let g:indent_guides_start_level       = 2  ' 从第二层开始可视化显示缩进
5. ' ig 打开/关闭 vim-indent-guides
13、标志无效空格

bronson/vim-trailing-whitespace

推荐等级:★★★★★

将代码行最后无效的空格标红

vimrc中配置如下:

1. 'for show no user whitespaces
2. Bundle 'bronson/vim-trailing-whitespace'
3. map <leader><space> :FixWhitespace<cr>    ' +space去掉末尾空格
14、快速移动

插件:Lokaltog/vim-easymotion

推荐等级:★★★★★

效率提升杀手锏,跳转到光标后任意位置

vimrc中配置如下:

1. '更高效的移动 // + w/f/l
2. Bundle 'Lokaltog/vim-easymotion'
15、括号匹配跳转

插件:vim-scripts/matchit.zip

推荐等级:★★★☆☆

匹配成对的标签,在()、''、甚至HTML标签之间快速跳转,快捷键为% vimrc中配置如下:

1. Bundle 'vim-scripts/matchit.zip'
16、自动补全

插件:Valloric/YouCompleteMe

推荐等级:★★★★★

强烈推荐 Ubuntu13.04配置YCM可参考这里

17、宏定义补全

插件:SirVer/ultisnips

推荐等级:★★★★★

配合YCM使用,双剑合璧,方便快捷,强烈推荐

开发时,我经常要输入相同的代码片断,比如 if-else、switch 语句,ultisnips可以快速插入我们自定义的代码片段,实现高效补全。 UltiSnips 预定义了几十种语言常用的代码模板,位于~/.vim/bundle/UltiSnips/UltiSnips/,UltiSnips 有一套自己的代码模板语法规则。 vimrc中配置如下:

1. '快速插入代码片段
2. Bundle 'SirVer/ultisnips'
3. let g:UltiSnipsExpandTrigger = '<tab>'
4. let g:UltiSnipsJumpForwardTrigger = '<tab>'
5. let g:UltiSnipsJumpBackwardTrigger='<s-tab>'
6. '定义存放代码片段的文件夹 .vim/snippets下,使用自定义和默认的,将会的到全局,有冲突的会提示
7. let g:UltiSnipsSnippetDirectories=['snippets''bundle/ultisnips/UltiSnips']
18、快速加减注释

插件:scrooloose/nerdcommenter

推荐等级:★★★★★

快速批量注释,方便好用

常用操作:

<leader>cc,注释当前选中文本,如果选中的是整行则在每行首添加 //,如果选中

一行的部分内容则在选中部分前后添加分别 /、/;

<leader>cu,取消选中文本块的注释。

更多内容见帮助文档。

1. Bundle 'scrooloose/nerdcommenter'
2. let NERDSpaceDelims = 1
19、快速加环绕符

tpope/vim-surround 详情见帮助文档 配合使用增强版命令重复 [https://github.com/tpope/vim-repeat| pope/vim-repeat ] vimrc中配置如下:

1. Bundle 'tpope/vim-surround'
2. 'for repeat -> enhance surround.vim, . to repeat command
3. Bundle 'tpope/vim-repeat'
20、自动括号补全

插件:Raimondi/delimitMate

推荐等级:★★★★☆

vimrc中配置如下:

1. '自动补全单引号,双引号等
2. Bundle 'Raimondi/delimitMate'
3. ' for python docstring ',优化输入
4. au FileType python let b:delimitMate_nesting_quotes = [''']
21、代码对齐

插件:godlygeek/tabular

推荐等级:★★★★★

vimrc中配置如下:

1. 'for code alignment
2. Bundle 'godlygeek/tabular'
3. ' b                 按=号对齐代码 [Tabular插件]
4. nmap <leader>bb :Tab /=<CR>
5. ' n                 自定义对齐    [Tabular插件]
6. nmap <leader>bn :Tab /
22、静态代码分析

插件:scrooloose/syntastic

推荐等级:★★★★☆

syntastic是一款支持多语言的实时语法检查插件。在 syntastic 的作用下,编码中、编译前,所有语法错误都将被抓出来并 呈现给你。

vimrc中配置如下:

01. ' 使用pyflakes,速度比pylint快
02. Bundle 'scrooloose/syntastic'
03. let g:syntastic_error_symbol = '?'  'set error or warning signs
04. let g:syntastic_warning_symbol = '?'
05. let g:syntastic_check_on_open=1
06. let g:syntastic_enable_highlighting = 0
07. 'let g:syntastic_python_checker='flake8,pyflakes,pep8,pylint'
08. let g:syntastic_python_checkers=['pyflakes']
09. 'highlight SyntasticErrorSign guifg=white guibg=black
10.  
11. let g:syntastic_cpp_include_dirs = ['/usr/include/']
12. let g:syntastic_cpp_remove_include_errors = 1
13. let g:syntastic_cpp_check_header = 1
14. let g:syntastic_cpp_compiler = 'clang++'
15. let g:syntastic_cpp_compiler_options = '-std=c++11 -stdlib=libstdc++'
16. let g:syntastic_enable_balloons = 1 'whether to show balloons
23、快速跳转到TODO列表

插件:vim-scripts/TaskList.vim

推荐等级:★★★★☆

查看并快速跳转到代码中的TODO列表。重构代码时一般通读,标记修改位置,非常实用

vimrc中配置如下:

1. Bundle 'vim-scripts/TaskList.vim'
2. map <leader>td <Plug>TaskList
24、维基百科

插件:vim-scripts/vimwiki

推荐等级:★★★★☆

vim下的维基百科,我的博客就是用vimwiki写的。

vimrc中配置如下:

01. Bundle 'vim-scripts/vimwiki'
02. let g:vimwiki_w32_dir_enc     = 'utf-8' ' 设置编码
03. let g:vimwiki_use_mouse       = 1       ' 使用鼠标映射
04. let g:vimwiki_valid_html_tags = 'a,img,b,i,s,u,sub,sup,br,hr,div,del,code,red,center,left,right,h3,h4,h3,h4,h5,h6,pre,script,style'
05. ' 声明可以在wiki里面使用的HTML标签
06. ' 对中文用户来说,我们并不怎么需要驼峰英文成为维基词条
07. let g:vimwiki_camel_case = 0
08.  
09. let blog = {}
10. if g:isWIN
11. if g:atCompany
12. let blog.path          = 'D:/Files/Files/mysite/wiki/'
13. let blog.path_html     = 'D:/Files/Files/mysite/html/'
14. let blog.template_path = 'D:/Files/Files/mysite/templates/'
15. let blog.nested_syntaxes = {'python''python''c++''cpp'}
16. else
17. let blog.path          = 'D:/Files/mysite/wiki/'
18. let blog.path_html     = 'D:/Files/mysite/html/'
19. let blog.template_path = 'D:/Files/mysite/templates/'
20. let blog.nested_syntaxes = {'python''python''c++''cpp'}
21. endif
22. else
23. let blog.path          = '~/mysite/wiki/'
24. let blog.path_html     = '~/mysite/html/'
25. let blog.template_path = '~/mysite/templates/'
26. endif
27. let blog.template_default  = 'site'
28. let blog.template_ext      = '.html'
29. let blog.auto_export       = 1
30.  
31. let g:vimwiki_list = [blog]
25、多光标批量操作

插件:terryma/vim-multiple-cursors

推荐等级:★★★☆☆

vimrc中配置如下:

1. 'for mutil cursor
2. Bundle 'terryma/vim-multiple-cursors'
3. let g:multi_cursor_use_default_mapping=0
4. ' Default mapping
5. let g:multi_cursor_next_key='<C-m>'
6. let g:multi_cursor_prev_key='<C-p>'
7. let g:multi_cursor_skip_key='<C-x>'
8. let g:multi_cursor_quit_key='<Esc>'
26、python语法高亮
1. 'python syntax highlight
2. Bundle 'hdima/python-syntax'
3. let python_highlight_all = 1
27、其他说明

在我的vimrc中使用了ctags,需要安装

sudo apt-get install ctags

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值