<link rel="prev" href="http://www.ruanyifeng.com/blog/2018/09/weekly-issue-22.html" title="每周分享第 22 期" />
<link rel="next" href="http://www.ruanyifeng.com/blog/2018/09/bash-wildcards.html" title="命令行通配符教程" />
<title>Vim 配置入门 - 阮一峰的网络日志</title>
/*
window.addEventListener(‘load’, function(event) {
setTimeout(function () {
hab(’#sup-post-2’);
hab(’#cre-inner’);
}, 1000);
});
*/
<div id="header">
<div id="header-inner">
<div id="header-content">
<div id="header-name">阮一峰的网络日志 <span id="site_location"> » <a href="http://www.ruanyifeng.com/blog/" accesskey="1">首页</a></span><span id="site_archive"> » <a href="http://www.ruanyifeng.com/blog/archives.html">档案</a></span>
</div>
</div>
<div id="content">
<div id="content-inner">
<div id="alpha">
<div id="alpha-inner">
<div id="entry-2021" class="entry-asset asset hentry">
<div class="asset-header">
- 上一篇:每周分享第 22 期
- 下一篇:命令行通配符教程
<div class="entry-categories">
<p>分类<span class="delimiter">:</span></p>
<ul>
<li><a href="http://www.ruanyifeng.com/blog/developer/" rel="tag">开发者手册</a></li>
</ul>
</div>
Vim 配置入门
<div class="asset-content entry-content" id="main-content">
<!-- div class="asset-body" -->
<p>Vim 是最重要的编辑器之一,主要有下面几个优点。</p>
<!-- /div -->
<!-- div id="more" class="asset-more" -->
<p><img src="https://www.wangbase.com/blogimg/asset/201809/bg2018091601.jpg" alt="" title="" /></p>
- 可以不使用鼠标,完全用键盘操作。
- 系统资源占用小,打开大文件毫无压力。
- 键盘命令变成肌肉记忆以后,操作速度极快。
- 服务器默认都安装 Vi 或 Vim。
Vim 的配置不太容易,它有自己的语法,许许多多的命令。我总是记不清楚,所以就整理了下面这篇文章,列出主要配置项的含义。
一、基础知识
Vim 的全局配置一般在/etc/vim/vimrc
或者/etc/vimrc
,对所有用户生效。用户个人的配置在~/.vimrc
。
如果只对单次编辑启用某个配置项,可以在命令模式下,先输入一个冒号,再输入配置。举例来说,set number
这个配置可以写在.vimrc
里面,也可以在命令模式输入。
:set number
配置项一般都有"打开"和"关闭"两个设置。"关闭"就是在"打开"前面加上前缀"no"。
" 打开 set number
" 关闭
set nonumber
上面代码中,双引号开始的行表示注释。
查询某个配置项是打开还是关闭,可以在命令模式下,输入该配置,并在后面加上问号。
:set number?
上面的命令会返回number
或者nonumber
。
如果想查看帮助,可以使用help
命令。
:help number
二、基本配置
(1)
set nocompatible
不与 Vi 兼容(采用 Vim 自己的操作命令)。
(2)
syntax on
打开语法高亮。自动识别代码,使用多种颜色显示。
(3)
set showmode
在底部显示,当前处于命令模式还是插入模式。
(4)
set showcmd
命令模式下,在底部显示,当前键入的指令。比如,键入的指令是2y3d
,那么底部就会显示2y3
,当键入d
的时候,操作完成,显示消失。
(5)
set mouse=a
支持使用鼠标。
(6)
set encoding=utf-8
使用 utf-8 编码。
(7)
set t_Co=256
启用256色。
(8)
filetype indent on
开启文件类型检查,并且载入与该类型对应的缩进规则。比如,如果编辑的是.py
文件,Vim 就是会找 Python 的缩进规则~/.vim/indent/python.vim
。
三、缩进
(9)
set autoindent
按下回车键后,下一行的缩进会自动跟上一行的缩进保持一致。
(10)
set tabstop=2
按下 Tab 键时,Vim 显示的空格数。
(11)
set shiftwidth=4
在文本上按下>>
(增加一级缩进)、<<
(取消一级缩进)或者==
(取消全部缩进)时,每一级的字符数。
(12)
set expandtab
由于 Tab 键在不同的编辑器缩进不一致,该设置自动将 Tab 转为空格。
(13)
set softtabstop=2
Tab 转为多少个空格。
四、外观
(14)
set number
显示行号
(15)
set relativenumber
显示光标所在的当前行的行号,其他行都为相对于该行的相对行号。
(16)
set cursorline
光标所在的当前行高亮。
(17)
set textwidth=80
设置行宽,即一行显示多少个字符。
(18)
set wrap
自动折行,即太长的行分成几行显示。
set nowrap
关闭自动折行
(19)
set linebreak
只有遇到指定的符号(比如空格、连词号和其他标点符号),才发生折行。也就是说,不会在单词内部折行。
(20)
set wrapmargin=2
指定折行处与编辑窗口的右边缘之间空出的字符数。
(21)
set scrolloff=5
垂直滚动时,光标距离顶部/底部的位置(单位:行)。
(22)
set sidescrolloff=15
水平滚动时,光标距离行首或行尾的位置(单位:字符)。该配置在不折行时比较有用。
(23)
set laststatus=2
是否显示状态栏。0 表示不显示,1 表示只在多窗口时显示,2 表示显示。
(24)
set ruler
在状态栏显示光标的当前位置(位于哪一行哪一列)。
五、搜索
(25)
set showmatch
光标遇到圆括号、方括号、大括号时,自动高亮对应的另一个圆括号、方括号和大括号。
(26)
set hlsearch
搜索时,高亮显示匹配结果。
(27)
set incsearch
输入搜索模式时,每输入一个字符,就自动跳到第一个匹配的结果。
(28)
set ignorecase
搜索时忽略大小写。
(29)
set smartcase
如果同时打开了ignorecase
,那么对于只有一个大写字母的搜索词,将大小写敏感;其他情况都是大小写不敏感。比如,搜索Test
时,将不匹配test
;搜索test
时,将匹配Test
。
六、编辑
(30)
set spell spelllang=en_us
打开英语单词的拼写检查。
(31)
set nobackup
不创建备份文件。默认情况下,文件保存时,会额外创建一个备份文件,它的文件名是在原文件名的末尾,再添加一个波浪号(〜)。
(32)
set noswapfile
不创建交换文件。交换文件主要用于系统崩溃时恢复文件,文件名的开头是.
、结尾是.swp
。
(33)
set undofile
保留撤销历史。
Vim 会在编辑时保存操作历史,用来供用户撤消更改。默认情况下,操作记录只在本次编辑时有效,一旦编辑结束、文件关闭,操作历史就消失了。
打开这个设置,可以在文件关闭后,操作记录保留在一个文件里面,继续存在。这意味着,重新打开一个文件,可以撤销上一次编辑时的操作。撤消文件是跟原文件保存在一起的隐藏文件,文件名以.un~
开头。
(34)
set backupdir=~/.vim/.backup// set directory=~/.vim/.swp// set undodir=~/.vim/.undo//
设置备份文件、交换文件、操作历史文件的保存位置。
结尾的//
表示生成的文件名带有绝对路径,路径中用%
替换目录分隔符,这样可以防止文件重名。
(35)
set autochdir
自动切换工作目录。这主要用在一个 Vim 会话之中打开多个文件的情况,默认的工作目录是打开的第一个文件的目录。该配置可以将工作目录自动切换到,正在编辑的文件的目录。
(36)
set noerrorbells
出错时,不要发出响声。
(37)
set visualbell
出错时,发出视觉提示,通常是屏幕闪烁。
(38)
set history=1000
Vim 需要记住多少次历史操作。
(39)
set autoread
打开文件监视。如果在编辑过程中文件发生外部改变(比如被别的编辑器编辑了),就会发出提示。
(40)
set listchars=tab:»■,trail:■ set list
如果行尾有多余的空格(包括 Tab 键),该配置将让这些空格显示成可见的小方块。
(41)
set wildmenu set wildmode=longest:list,full
命令模式下,底部操作指令按下 Tab 键自动补全。第一次按下 Tab,会显示所有匹配的操作指令的清单;第二次按下 Tab,会依次选择各个指令。
七、参考链接
(完)
<!-- /div -->
</div>
<script type="text/javascript" src="/newwindow.js"></script>
<div class="asset-footer">
文档信息
- 版权声明:自由转载-非商用-非衍生-保持署名(创意共享3.0许可证)
- 发表日期: 2018年9月16日
- 更多内容: 档案 » 开发者手册
- 文集:《前方的路》,《未来世界的幸存者》
- 社交媒体: twitter, weibo
- 2018.11.07: awk 入门教程
<div class="entry-body"> awk是处理文本文件的一个应用程序,几乎所有 Linux 系统都自带这个程序。 </div>
- 2018.11.05: Page Lifecycle API 教程
<div class="entry-body"> 两周前,我介绍了 Page Visibility API。有了它,就可以监听各种情况的网页卸载。 </div>
- 2018.10.25: Page Visibility API 教程
<div class="entry-body"> 一、简介
有时候,开发者需要知道,用户正在离开页面。常用的方法是监听下面三个事件。
</div>
- 2018.10.18: Flexbox 布局的最简单表单
<div class="entry-body"> 弹性布局(Flexbox)逐渐流行,越来越多人使用,因为它写 CSS 布局真是太方便了。 </div>
广告(购买广告位)
<div id="comments" class="comments"> <h2 class="comments-header">留言(24条)</h2> <div id="comments-content" class="comments-content" style="clear: left;"> <div id="comment-393189" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author"><a title="https://www.libinx.com" href="https://www.libinx.com" target="_blank" rel="nofollow">libinx</a></span>
说:
func SetTitle()
call setline(1, "\#!/usr/bin/python")
call setline(2, "\# -*- coding=utf8 -*-")
call setline(3, "\"\"\"")
call setline(4, "\# @Author : Li Bin")
call setline(5, "\# @Created Time : ".strftime("%Y-%m-%d %H:%M:%S"))
call setline(6, "\# @Description : ")
call setline(7, "\"\"\"")
normal G
normal o
normal o
endfunc
autocmd bufnewfile *.py call SetTitle()<div id="comment-393190" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author">fuchao</span>
说:
可以用现成的吖,https://github.com/amix/vimrc
<div id="comment-393197" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author">必填</span>
说:
习惯用vim的人一定不要错过chrome插件vimium:https://chrome.google.com/webstore/detail/vimium/dbepggeogbaibhgnhhndojpepiihcmeb?hl=en
有了这个神器,我浏览网页都不大需要用鼠标了。
<div id="comment-393201" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author">137377329</span>
说:
CentOS 默认安装 vim,不过放在/usr/bin/vi。
<div id="comment-393202" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author">pengy</span>
说:
阮哥,我建议你弄个app,我们玩手机的直接上app看你的博客
<div id="comment-393203" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author">flw</span>
说:
阮老师, `==` 可不是「取消全部缩进」的意思,而是「自动缩进」的意思。
<div id="comment-393206" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author"><a title="https://jisuye.com" href="https://jisuye.com" target="_blank" rel="nofollow">ixx</a></span>
说:
来,让我们看一下Vim用户有多少
<div id="comment-393209" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author">XX</span>
说:
liunx等系统命令行界面默认已安装。这让VIM的使用率提高很多。
大量的快捷键并不能提高多少效率,而快捷键的学习成本则过高。
一般IT编码工,多数时候要在多套不同的工具间轮换使用,不同工具有相同功能但快捷键不同,即使移植与重定义快捷键也难保持完全一致,切换/记忆/学习/不混淆,的成本,大了点。
WINDOWS的记事本这类的,最好不过。零学习成本。
毕竟,大多数时候,编码工不是打字员,多数时候,是在思考。
萝卜白菜各有所爱,说VIM好,也无不妥。<div id="comment-393216" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author">吴星</span>
说:
vimer 分为3级
1级 不用鼠标掌握基本操作
2级 自定义默认配置和快捷键
3级 摆弄各种插件<div id="comment-393217" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author">foo</span>
说:
vi的优点跟它的缺点比起来,简直不值一提。
<div id="comment-393254" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author">zoe</span>
说:
引用pengy的发言:
阮哥,我建议你弄个app,我们玩手机的直接上app看你的博客
小程序更方便,不用下app
<div id="comment-393258" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author">KingKong</span>
说:
set softtabstop=2
set tabstop=2
这两个有什么区别?<div id="comment-393259" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author"><a title="https://ahuigo.github.io" href="https://ahuigo.github.io" target="_blank" rel="nofollow">ahuigo</a></span>
说:
iterm2 默认的 Profile - Terminal: Report Terminal Type = xterm , 导致nvim 乱码`:5:130m`.
可将 Report Terminal Type 改成 `xterm-256color` 或则 vim `:let &t_Co=8`
<div id="comment-393275" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author">章鱼来</span>
说:
引用pengy的发言:
阮哥,我建议你弄个app,我们玩手机的直接上app看你的博客
阮老师的博客是自适应的,手机也能看
<div id="comment-393375" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author"><a title="http://meethigher.top" href="http://meethigher.top" target="_blank" rel="nofollow">程传晨</a></span>
说:
看得我想要入门vim了
<div id="comment-393500" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author">xxxx</span>
说:
引用fuchao的发言:
可以用现成的吖,https://github.com/amix/vimrc
貌似这个配置不能用了!
<div id="comment-393516" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author">路人</span>
说:
请问macbook pro买了带bar的怎么办?实在是习惯不了没有esc的日子。
<div id="comment-393532" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author"><a title="http://wuchuheng@163.com" href="http://wuchuheng@163.com" target="_blank" rel="nofollow">阿衡</a></span>
说:
学习vim的时间成本太高了。如果只是玩一玩又想短时间提高工作效率太难了。
<div id="comment-393576" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author">Alchemist</span>
说:
@XX:
对不起,多数码农就是打字员。
<div id="comment-393586" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author">suboku</span>
说:
引用pengy的发言:
阮哥,我建议你弄个app,我们玩手机的直接上app看你的博客
可以用rss软件订阅rss源:http://www.ruanyifeng.com/blog/atom.xml
安卓的手机我用inoreader,看阮老师的rss没什么问题<div id="comment-393774" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author"><a title="https://github.com/Leptune/vim-for-coding" href="https://github.com/Leptune/vim-for-coding" target="_blank" rel="nofollow">leptune</a></span>
说:
我的vim配置,欢迎star和fork
https://github.com/Leptune/vim-for-coding<div id="comment-393847" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author"><a title="https://royaso.github.io" href="https://royaso.github.io" target="_blank" rel="nofollow">royaso</a></span>
说:
只能说,很水,跟上篇的glob通配符一样,水的很,
这么水的翻译还是让我这种没啥技术的人来搞吧,
多介绍点新奇的,前沿的有意思的文章吧
我一直认为vim已经是被玩烂的了,虽然每次我都会点进去.它比emacs好入门这些选项设置还是多翻翻:help 'option'就可以了
<div id="comment-394541" class="comment"> <div class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author"><a title="http://witheloov.com/" href="http://witheloov.com/" target="_blank" rel="nofollow">whitek</a></span>
说:
不行,我得抽个时间好好记一下的确现在就会一点vim操作记住了之后操作完全脱离鼠标
<div id="comment-396244" class="comment"> <div id="comment-last" class="inner"> <div class="comment-header"> <div class="asset-meta">
<span class="vcard author">pageliu16</span>
说:
简单实用的配置,谢谢,正在研究中.
</div> <div class="comments-open" id="comments-open"> <h2 class="comments-open-header">我要发表看法</h2> <div class="comments-open-content"> <div id="comment-greeting"></div> <form method="post" action="http://www.ruanyifeng.com/cgi-bin/mtos/mt-comments.cgi" name="comments_form" id="comments-form" onsubmit="return pleaseWait();"> <input type="hidden" name="static" value="1" /> <input type="hidden" name="entry_id" value="2021" /> <input type="hidden" name="__lang" value="en" /> <input type="hidden" name="parent_id" value="" id="comment-parent-id" /> <input type="hidden" name="armor" value="1" /> <input type="hidden" name="preview" value="" /> <input type="hidden" name="sid" value="" /> <div id="comments-open-data"> <div id="comments-open-text"> <p><label for="comment-text">您的留言 (HTML标签部分可用)</label></p> <p><textarea id="comment-text" name="text" rows="10" cols="50"></textarea></p> </div> <div id="comment-form-name"> <p><label for="comment-author">您的大名:</label></p> <p><input id="comment-author" name="author" size="30" value="" /> <span class="hint"> «-必填</span></p> </div> <div id="comment-form-email"> <p><label for="comment-email">电子邮件:</label></p> <p><input id="comment-email" name="email" size="30" value="" /> <span class="hint"> «-必填,不公开</span></p> </div> <div id="comment-form-url"> <p><label for="comment-url">个人网址:</label></p> <p><input id="comment-url" name="url" size="30" value="" /> <span class="hint"> «-我信任你,不会填写广告链接</span></p> </div> <div id="comment-form-remember-me"> <p> <label for="comment-bake-cookie">记住个人信息?</label><input type="checkbox" id="comment-bake-cookie" name="bakecookie" onclick="!this.checked?forgetMe(document.comments_form):rememberMe(document.comments_form)" value="1" accesskey="r" /></p> </div> </div> <div id="comment-form-reply" style="display:none"> <input type="checkbox" id="comment-reply" name="comment_reply" value="" onclick="mtSetCommentParentID()" /> <label for="comment-reply" id="comment-reply-label"></label> </div> <div id="comments-open-captcha"></div> <div id="comments-open-footer">
正在发表您的评论,请稍候
<p><input type="submit" accesskey="s" name="post" id="comment-submit" value="发表" /> <span class="hint"> «- 点击按钮</span></p> </div> </form> </div> </div>
</div> </div> </div> </div> <script type="text/javascript" src="http://www.ruanyifeng.com/blog/js/prism.js"></script> <script type="text/javascript" src="/blog/checker.js"></script> <div id="footer">
</div> </div>
</div> </div>
除了文章提到的设置,在我的 .vimrc 还添加了匹配 Python 开发的配置,每次新建一个 .py 的文件都可以自动添加脚本的头部信息,很方便。