vim简单配置

<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">
                                <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 配置入门

                                        <p class="vcard author">作者: <a class="fn url" href="http://www.ruanyifeng.com">阮一峰</a></p>
                                <p>日期: <a href="http://www.ruanyifeng.com/blog/2018/09/"><abbr class="published" title="2018-09-16T09:32:56+08:00">2018年9月16日</abbr></a></p>

珠峰培训
                            <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">

文档信息

优达学城

腾讯课堂

  • 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>
    

    说:

    除了文章提到的设置,在我的 .vimrc 还添加了匹配 Python 开发的配置,每次新建一个 .py 的文件都可以自动添加脚本的头部信息,很方便。

    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"> &laquo;-必填</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"> &laquo;-必填,不公开</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"> &laquo;-我信任你,不会填写广告链接</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"> &laquo;- 点击按钮</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>
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值