基本配置

不用任何插件的情况下,先按如下配置:

set nu
syntax on
set hlsearch set tabstop=4
set shiftwidth=4
set expandtab
set smartcase
set ic colorscheme srcery-drk

Vundle

Vundle是Vim的插件管理器,像NeoBundle也是基于Vundle实现。
虽然Vim插件可以独立安装,但如果换了台机器,使用Vundle只需要copy一份.vimrc即可。

安装方法并不复杂,先clone到~/.vim目录下:

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

在~/.vimrc头部加上以下内容:

set nocompatible
filetype off set rtp+=~/.vim/bundle/Vundle.vim
call vundle#begin() Plugin 'VundleVim/Vundle.vim'
Plugin 'tpope/vim-fugitive'
Plugin 'git://git.wincent.com/command-t.git'
Plugin 'rstacruz/sparkup', {'rtp': 'vim/'} call vundle#end() " required
filetype plugin indent on " required

保存,在vim里执行PluginInstall,等过程执行结束即可。

或者在命令行执行以下命令也是相同的效果:

vim +PluginInstall +qall

查看帮助:

:h vundle

在~/.vimrc声明插件,例如:

Plugin 'scrooloose/nerdtree'
Plugin 'shougo/vimshell.vim'

基本命令:

" :PluginList       - 列出所有插件
" :PluginInstall - 安装插件
" :PluginInstall! - 更新插件
" :PluginSearch foo - 搜索foo插件
" :PluginClean - 移除未使用插件

NerdTree

目录树插件,前提安装了Vundle,在~/.vimrc声明了NerdTree:

Plugin 'scrooloose/nerdtree'

在vim中执行以下命令即可完成安装:

:source %
:PluginInstall

我的NerdTree配置如下:

" ============ NERDTree ============
" open NERDTree by default
autocmd vimenter * NERDTree " synchronize NERDTree with current opened file
autocmd BufEnter * lcd %:p:h " open NERDTree automatically when vim starts up if no files were specified
autocmd StdinReadPre * let s:std_in=1
autocmd VimEnter * if argc() == 0 && !exists("s:std_in") | NERDTree | endif " open NERDTree automatically when vim starts up on opening a directory
autocmd StdinReadPre * let s:std_in=1
autocmd VimEnter * if argc() == 1 && isdirectory(argv()[0]) && !exists("s:std_in") | exe 'NERDTree' argv()[0] | wincmd p | ene | endif " open NERDTree with Ctrl+n
map <C-n> :NERDTreeToggle<CR> " view the current buffer in NERDTree
map <leader>r :NERDTreeFind<cr>
" close vim if the only window left open is a NERDTree
autocmd bufenter * if (winnr("$") == 1 && exists("b:NERDTree") && b:NERDTree.isTabTree()) | q | endif " change arrows
let g:NERDTreeDirArrowExpandable = '▸'
let g:NERDTreeDirArrowCollapsible = '▾' " show hidden files by default
let NERDTreeShowHidden=1

NerdTree的常用快捷键:

快捷键 说明
? 查看帮助
m 呼出菜单,对当前目录进行操作
r 刷新目录
F 显示、隐藏隐藏文件
A 目录树切全屏
go 打开文件,光标停留在目录树上
i|gi 水平打开窗口
s|gs 垂直打开窗口
ctrl+w+h|j|k|l 方向键选择窗口
ctrl+w+w 切窗口
t|T 在tab打开窗口
gt|gT 切tab

如果用git,有个NerdTree的扩展插件,可以在目录树中显示文件的git status。
安装仍然是通过Vundle,插件声明如下:

Plugin 'Xuyuanp/nerdtree-git-plugin'

TagBar

个人阅读代码时,如果IDE打开的是另一个工程,一般不会将工程导入IDE再读,而是用Vim读代码。
只是跳转到变量或者函数的功能只是通过gD的话,跳转的位置并不是很准确。

TagBar可以生成文件中的变量、函数列表。

用Vundle安装,在~/.vimrc加上以下声明:

Plugin 'majutsushi/tagbar'

保存,执行:PluginsInstall,等待过程结束。

个人使用的配置如下:

let g:tagbar_width = 30
nmap <F10> :TagbarToggle<CR>
let g:tagbar_autopreview = 1
let g:tagbar_sort = 0

source配置文件后,重新进入vim,按下F10呼出TagBar。

macOS可能出现以下提示:

Tagbar: Ctags doesn't seem to be Exuberant Ctags!

TagBar依赖Exuberant Ctags 5.5,这种情况brew install ctags后重新进入vim即可。

Vim - 常用配置的更多相关文章

  1. vim常用配置 vimrc文件

    自从接触vim,自己瞎鼓捣.vimrc也有一段时间了.收集记录一下好用的配置. 一.奇技淫巧 1.折叠代码 折叠代码常常用在代码块较长的情况下,比如一个文件里定义了很多个函数,或者注释.括号影响的阅读 ...

  2. Vim 常用配置及插件安装使用

    在 Linux 中习惯了 vim 编辑器. 找了一些资料后自己尝试配置起来了.下面是一些过程. 首先需要知道 vim 相关的配置都是写在 ~/.vimrc 文件中.我下面的笔记只配置了一些我常用的功能 ...

  3. Vim常用配置

    mkdir -p ~/.vim/bundle/Vundle.vim git clone https://github.com/gmarik/Vundle.vim.git ~/.vim/bundle/V ...

  4. Vim常用配置(~/.vimrc)(转载)

    原文地址:http://www.2cto.com/os/201309/246271.html " This must be first, beacuse it changes other o ...

  5. Vim常用命令及配置方案

    Vim常用命令及配置方案   几句话 很久之前就接触到vim,初学那阵觉得vim很酷炫,但确实对新手不是很友好.我也就简单看了下基本操作就上手了,但又不是长期在vim下工作,这就导致了每一次重新使用v ...

  6. vim+vundle配置

    Linux环境下写代码虽然没有IDE,但通过给vim配置几个插件也足够好用.一般常用的插件主要包括几类,查找文件,查找符号的定义或者声明(函数,变量等)以及自动补全功能.一般流程都是下载需要的工具,然 ...

  7. Vim 常用技巧:

    Vim 常用技巧: 将回车由默认的8个空格改为4个空格: 命令:set sw=4 修改tab为4空格: 命令:set ts=4 设置每一级的缩进长度: 命令:set shiftwidth=4 设置文件 ...

  8. VMware中安装CentOS7网络配置静态IP地址,常用配置和工具安装

    VMware中安装CentOS7网络配置静态IP地址,常用配置和工具安装在阿里云开源镜像地址下载镜像Index of /centos/7.2.1511/isos/x86_64/http://mirro ...

  9. Linux常用命令及vim的使用、vim常用插件(推荐)

    看了3篇文章,很好 vim中的区域拷贝 剪切,粘贴: 正常模式,移动光标到剪切的区域开始处,按v,进入可视模式,然后选择区域.按x键,剪切.到指定位置按p粘贴. 撤销按u 恢复按ctrl-r  简明 ...

随机推荐

  1. panda库------对数据进行操作---合并,转换,拼接

    >>> frame2 addr age name 0 beijing 12 zhang 1 shanghai 24 li 2 hangzhou 24 cao >>> ...

  2. [js高手之路] es6系列教程 - 迭代器与生成器详解

    什么是迭代器? 迭代器是一种特殊对象,这种对象具有以下特点: 1,所有对象都有一个next方法 2,每次调用next方法,都会返回一个对象,该对象包含两个属性,一个是value, 表示下一个将要返回的 ...

  3. 静态页面如何实现 include 引入公用代码

    一直以来,我司的前端都是用 php 的 include 函数来实现引入 header .footer 这些公用代码的,就像下面这样: <!-- index.php --> <!DOC ...

  4. ios开发——实用技术篇&三维旋转动画

    实现三位旋转动画的方法有很多种,这里介绍三种 一:UIView 1 [UIView animateWithDuration:1.0 animations:^{ 2 self.iconView.laye ...

  5. Spring+SpringMVC+MyBatis整合进阶篇(四)RESTful实战(前端代码修改)

    前言 前文<RESTful API实战笔记(接口设计及Java后端实现)>中介绍了RESTful中后端开发的实现,主要是接口地址修改和返回数据的格式及规范的修改,本文则简单介绍一下,RES ...

  6. Python cPickle模块

    新博客地址:http://gorthon.sinaapp.com/ 持久性就是指保持对象,甚至在多次执行同一程序之间也保持对象.通过本文,您会对 Python对象的各种持久性机制(从关系数据库到 Py ...

  7. Android UI 笔记

    EditText中添加小图标 <TextView android:layout_width="wrap_content" android:layout_height=&quo ...

  8. eslint使用

    参考文档 http://www.cnblogs.com/hahazexia/p/6393212.html http://blog.guowenfh.com/2016/08/07/ESLint-Rule ...

  9. [js插件开发教程]一步步开发一个可以定制配置的隔行变色小插件

    隔行变色功能,不用js,直接用css伪类就可以做,这个实例可以作为js插件开发很好的入门级实例.本文实现的隔行变色包括以下功能: 1,支持2种常用结构共存( div元素 和 表格类型 ) 2,一个页面 ...

  10. asp.net中利用Jquery+Ajax+Json实现无刷新分页(二)

    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="PageTest.aspx.cs ...