Vim配置及说明 IDE编程环境
来源:互联网 发布:linux密码忘了 编辑:程序博客网 时间:2024/06/06 17:56
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.sh2、插件管理
插件[ 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
- Vim配置及说明 IDE编程环境
- Vim配置及说明——IDE编程环境
- 【Vim】配置及说明——IDE编程环境
- Vim+IDE编程环境设置
- vim 配置成IDE环境
- VIM配置方法--手把手教你把Vim改装成一个IDE编程环境(图文)
- 将vim改装成IDE编程环境
- 将vim打造成IDE编程环境
- Vim改装成一个IDE编程环境
- 将vim打造成IDE编程环境
- vim改装成IDE编程环境
- 将vim 改成IDE编程环境
- Vim编程环境配置
- 配置 vim Python IDE 开发环境
- 配置 vim Python IDE 开发环境
- 把VIM配置成IDE开发环境
- 配置vim Python IDE 开发环境
- 配置vim Python IDE 开发环境
- 字符数组 与 字符指针(使用前分配内存)
- Leetcode_169_Majority Element
- 将spring的bean配置文件分模块定义
- linux驱动虚拟地址和物理地址的映射
- hdu1008
- Vim配置及说明 IDE编程环境
- pycurl: libcurl link-time ssl backend (nss) is different from compile-time ssl backend (none/other)
- 虚拟地址到物理地址的映射
- http状态码/http返回码详解
- Spring与JMX集成
- 在eclipse下使用java调用weka【第一步】
- ThinkPad T440s(20AQS01100)
- iOS NSString 和NSData 转换
- 第七章 查找 知识导图