vim的日常

in LinuxmacOS with 0 comment

语法

vim的配置

vim的全局配置一般在 /etc/vim/vimrc 或者 /etc/vimrc 。用户个人的配置在 ~/.vimrc

set shortmess=atI " 启动的时候不显示那个援助乌干达儿童的提示
syntax on
set number
set nocompatible " 不与 Vi 兼容(采用 Vim 自己的操作命令)。
set mouse=a " 支持使用鼠标。
set encoding=utf-8  " 使用 utf-8 编码
set t_Co=256 " 启用256色
filetype indent on " 开启文件类型检查,并且载入与该类型对应的缩进规则。比如,如果编辑的是.py文件,Vim 就是会找 Python 的缩进规则~/.vim/indent/python.vim
set autoindent " 按下回车键后,下一行的缩进会自动跟上一行的缩进保持一致。
set tabstop=2 " 按下 Tab 键时,Vim 显示的空格数
set shiftwidth=4 " 在文本上按下>>(增加一级缩进)、<<(取消一级缩进)或者==(取消全部缩进)时,每一级的字符数。
set foldenable " 允许折叠
set foldmethod=manual " 手动折叠

set relativenumber " 显示光标所在的当前行的行号,其他行都为相对于该行的相对行号。
set cursorline " 光标所在的当前行高亮
set textwidth=80 " 设置行宽,即一行显示多少个字符
set wrap " 自动折行,即太长的行分成几行显示
set nowrap " 关闭自动折行
set linebreak " 只有遇到指定的符号(比如空格、连词号和其他标点符号),才发生折行。也就是说,不会在单词内部折行。
set wrapmargin=2 " 指定折行处与编辑窗口的右边缘之间空出的字符数。
set scrolloff=5 " 垂直滚动时,光标距离顶部/底部的位置(单位:行)
set sidescrolloff=15 " 水平滚动时,光标距离行首或行尾的位置(单位:字符)。该配置在不折行时比较有用。
set laststatus=2 " 是否显示状态栏。0 表示不显示,1 表示只在多窗口时显示,2 表示显示。
set  ruler " 在状态栏显示光标的当前位置(位于哪一行哪一列)。

" 搜索
set showmatch " 光标遇到圆括号、方括号、大括号时,自动高亮对应的另一个圆括号、方括号和大括号
set hlsearch " 搜索时,高亮显示匹配结果
set incsearch " 输入搜索模式时,每输入一个字符,就自动跳到第一个匹配的结果
set ignorecase " 搜索时忽略大小写
set spell spelllang=en_us “ 打开英语单词的拼写检查
set nobackup " 不创建备份文件。默认情况下,文件保存时,会额外创建一个备份文件,它的文件名是在原文件名的末尾,再添加一个波浪号(〜)。
set noswapfile " 不创建交换文件。交换文件主要用于系统崩溃时恢复文件,文件名的开头是.、结尾是.swp。
set undofile ” 保留撤销历史

set undofile " 打开这个设置,可以在文件关闭后,操作记录保留在一个文件里面,继续存在。这意味着,重新打开一个文件,可以撤销上一次编辑时的操作。撤消文件是跟原文件保存在一起的隐藏文件,文件名以.un~开头

set backupdir=~/.vim/.backup//  
set directory=~/.vim/.swp//
set undodir=~/.vim/.undo// 
" 设置备份文件、交换文件、操作历史文件的保存位置。结尾的//表示生成的文件名带有绝对路径,路径中用%替换目录分隔符,这样可以防止文件重名
set autochdir " 自动切换工作目录。这主要用在一个 Vim 会话之中打开多个文件的情况,默认的工作目录是打开的第一个文件的目录。该配置可以将工作目录自动切换到,正在编辑的文件的目录
set noerrorbells " 出错时,不要发出响声
set visualbell " 出错时,发出视觉提示,通常是屏幕闪烁。
set history=1000 " Vim 需要记住多少次历史操作。
set autoread " 打开文件监视。如果在编辑过程中文件发生外部改变(比如被别的编辑器编辑了),就会发出提示

set listchars=tab:»■,trail:■
set list
" 如果行尾有多余的空格(包括 Tab 键),该配置将让这些空格显示成可见的小方块

set wildmenu
set wildmode=longest:list,full
" 命令模式下,底部操作指令按下 Tab 键自动补全。第一次按下 Tab,会显示所有匹配的操作指令的清单;第二次按下 Tab,会依次选择各个指令

插件安装

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

粘贴下面内容到 ~/.vimrc

set nocompatible              " be iMproved, required
filetype off                  " required

" set the runtime path to include Vundle and initialize
set rtp+=~/.vim/bundle/Vundle.vim
call vundle#begin()
" alternatively, pass a path where Vundle should install plugins
"call vundle#begin('~/some/path/here')

" let Vundle manage Vundle, required
Plugin 'VundleVim/Vundle.vim'

" The following are examples of different formats supported.
" Keep Plugin commands between vundle#begin/end.
" plugin on GitHub repo
" Plugin 'tpope/vim-fugitive'
" plugin from http://vim-scripts.org/vim/scripts.html
" Plugin 'L9'
" Git plugin not hosted on GitHub
" Plugin 'git://git.wincent.com/command-t.git'
" git repos on your local machine (i.e. when working on your own plugin)
" Plugin 'file:///home/gmarik/path/to/plugin'
" The sparkup vim script is in a subdirectory of this repo called vim.
" Pass the path to set the runtimepath properly.
" Plugin 'rstacruz/sparkup', {'rtp': 'vim/'}
" Install L9 and avoid a Naming conflict if you've already installed a
" different version somewhere else.
" Plugin 'ascenator/L9', {'name': 'newL9'}

" All of your Plugins must be added before the following line
call vundle#end()            " required
filetype plugin indent on    " required
" To ignore plugin indent changes, instead use:
"filetype plugin on
"
" Brief help
" :PluginList       - lists configured plugins
" :PluginInstall    - installs plugins; append `!` to update or just :PluginUpdate
" :PluginSearch foo - searches for foo; append `!` to refresh local cache
" :PluginClean      - confirms removal of unused plugins; append `!` to auto-approve removal
"
" see :h vundle for more details or wiki for FAQ
" Put your non-Plugin stuff after this line
Responses