当前位置:首页 > 技术分析 > 正文内容

我的VIM配置

ruisui884个月前 (01-10)技术分析27

写一篇关于VIM配置的文章,记录下自己的VIM配置,力求简洁实用。

VIM的配置保存在文件~/.vimrc中(Windows下是C:\Users\yourname \_vimrc)。VIM除了自身可配置项外,还可插件扩展。VIM的插件一般用vundle或vim-plug来管理,但我力求简单,不打算装太多插件,所以也不打算使用插件管理,直接手动安装插件。

文章分基础配置、插件和VIM高级用法三部分。同时适用Linux和Windows。

PART1 基础配置

以下配置相当于VIM的必备配置,没有这些配置感觉VIM少了什么。

set encoding=utf-8  "使用utf8编码
let mapleader=";"  "定义快捷键的前缀,即<Leader>

filetype plugin indent on "打开文件类型检测
syntax on  "开启语法高亮,并替换默认配色方案
set nowrap  "禁止折行

set incsearch  "开启实时搜索
set hlsearch  "搜索结果高亮
set ignorecase  "大小写不敏感
set smartcase  "如果搜索的pattern中含有大写字母,则大小写敏感

set gcr=a:block-blinkon0  "禁止光标闪烁,windows gVim有效,ubuntu无效
set guioptions-=m  "禁止显示菜单和工具条,windows gVim有效
set guioptions-=T

""--辅助信息
set laststatus=2  "总是显示状态栏
set ruler  "显示光标当前位置
set number  "显示行号
set cursorline  "高亮显示当前行
set cursorcolumn  "高亮显示当前列
set wildmenu  "输入命令点击Tab键时,会展示所有候选命令

""--制表符
set expandtab  "将制表符扩展为空格
set tabstop=4  "编辑时制表符占用空格数
set shiftwidth=4
set softtabstop=4  "让VIM把连续4个空格视为一个制表符

""--窗口相关操作
nnoremap <Leader>nw <C-W><C-W>  "遍历窗口
nnoremap <Leader>lw <C-W>l
nnoremap <Leader>hw <C-W>h
nnoremap <Leader>kw <C-W>k
nnoremap <Leader>jw <C-W>j
nnoremap <Leader>= <C-W>+  "增加窗口高度
nnoremap <Leader>- <C-W>-  "减小窗口高度

PART2 插件

VIM有一套自己的脚本语言vimscript,通过这种脚本语言可以实现与vim交互,达到扩展功能的目的。 一组vimscript就是就是一个vim插件。~/.vim是存放插件的默认目录(Windows下是C:\Users\yourname\vimfiles,可以通过命令:set runtimepath? 确认)。

nerdcommenter

  1. 功能: 快速注释
  2. 地址: https://github.com/preservim/nerdcommenter
  3. 安装方法: 直接将github代码仓里的plugin/nerdcommenter.vim和autoload/nerdcommenter.vim两个文件复制到~/.vim/plugin和~/.vim/autoload下即可
  4. 用法:如下是插件自带的命令绑定
<leader>cc  "注释
<leader>cu  "取消注释
<leader>ca  "切换为第二种注释符, 比如C文件第一种注释符是/* */,第二种注释符是//
<leader>cs  "更性感的注释
<leader>cm  "紧凑型注释

nerdtree

  1. 功能: 文件浏览
  2. 地址: https://github.com/preservim/nerdtree
  3. 安装方法: 下载代码,将autoload lib/nerdtree nerdtree_plugin plugin syntax这几个目录复制到~/.vim文件夹下
  4. 用法:需要在vimrc中增加如下配置
nnoremap <leader>fl :NERDTreeToggle<CR>  "打开/关闭文件浏览窗口,选中文件后回车打开
                                         "在nerdtree窗口中输入cd命令,则切换VIM的CWD到选中的目录

PART3 VIM高级用法

多文件搜索vimgrep

:vim[grep] {pattern} {file}  "其中file部分,*表示当前目录,**表示当前目录和子目录
:cw or :copen  "打开Quickfix列表,vimgrep的搜索结果在Quickfix中
:cn or :cnext "下一个结果
:cp or :cprevious "上一个结果
:vim // {file}  "如果模式为空,则使用最近一次的查找模式
:colder  "最后10个搜索结果会被记录,此命令跳到上一个搜索记录
:cnewer

快捷键绑定

nnoremap <Leader>sw :copen 15<CR>  "打开quickfix窗口,高度15行(默认是10行)
nnoremap <Leader>sc :cclose<CR>  "关闭quickfix窗口
nnoremap <Leader>sn :cnext<CR>  "quickfix下一个结果
nnoremap <Leader>sr :cprevious<CR>  "quickfix上一个结果
nnoremap <Leader>ss :vim //j **<CR>  "以当前匹配模式搜索
nnoremap <Leader>so :colder<CR>  "旧一次的搜索结果
nnoremap <Leader>se :cnewer<CR>  "新一次的搜索结果

替换命令

  • 常规替换命令:
:[range]s[ubstitute]/{pattern}/{string}/[flags]
" range: %表示全文
" flags: c表示要确认
  • 多文件替换:
:args *.*  "生成文件列表
:argdo %s/oldword/newword/gc | update  "对args里的每个文件执行替换命令

多buffer操作

当一个文件加载到内存时,VIM为其创建一个buffer

:ls  "列出所有的buffer
:b 5  "跳到编号为5的buffer
:b name  "跳到文件名为name的buffer,支持部分名字和tab补全
<C-6>  "跳到上一个buffer
:bw  "关闭当前buffer

自动补全

ctrl-n, ctrl-p  "弹出补全窗口
ctrl-e  "取消补全窗口

汇总后的.vimrc文件

见 https://github.com/jian-soft/vimrc



参考文章: https://github.com/yangyangwithgnu/use_vim_as_ide

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/152.html

标签: nerdtree
分享给朋友:

“我的VIM配置” 的相关文章

壹啦罐罐 Android 手机里的 Xposed 都装了啥

这是少数派推出的系列专题,叫做「我的手机里都装了啥」。这个系列将邀请到不同的玩家,从他们各自的角度介绍手机中最爱的或是日常使用最频繁的 App。文章将以「每周一篇」的频率更新,内容范围会包括 iOS、Android 在内的各种平台和 App。本期继续歪楼,由少数派撰稿作者@壹啦罐罐介绍他正在使用的...

Vue真是太好了 壹万多字的Vue知识点 超详细!

1??、Vue和其他两大框架的区别Angular 学习成本太高React 代码可读性差Vue 学习成本较低 很容易上手VUE官方: https://cn.vuejs.org/v2/guide/comparison.html?2??、Vue是什么Vue是一套用于构建用户界面的渐进式框架 "前端...

VUE 技术栈

官网链接:https://cn.vuejs.org/什么是vue:渐进式JavaScript 框架vue-cli链接:https://cli.vuejs.org/vue-cli安装:npm install -g @vue/clivue -V创建一个项目:vue create xxxxxx模版语法:文...

一套代码,多端运行——使用Vue3开发兼容多平台的小程序

介绍Vue3发布已经有一段时间了,从目前来看,其生态还算可以,也已经有了各种组件库给予了支持,但是不管是Vue3还是Vue2都无法直接用来开发小程序,因此国内一些技术团队针对Vue开发了一些多端兼容运行的开发框架,今天来体验一下使用Taro来体验一下使用Vue3开发多平台运行的小程序,以便于兼容各大...

复盘总结:从0到1,企业微信小程序开发11步走

作者复盘了从域名准备到内容发布的整个过程,这是项目团队一起回忆整个产品总结出来的经验,值得我们学习,与大家分享。去年接手了两个微信小程序的开发项目,作为一位产品人员,在和开发供应商进行磨合的时候也遇到了许许多多的问题。如今项目已进入收尾阶段,之前也参考了许多其他做微信小程序的同行同事的经验,再做一次...

微信开发的五大价值应用

企业形象展示微网站是企业在移动互联网时代完美展示企业及品牌形象的最佳选择,表现内容丰富、实时更新、形式多样化,保证品牌形象的有效传播!微网站带来的轻营销模式,更适应现代网站的发展模式,所以微网站的开发也具有更好的商业营销效果,其面对的受众是7亿多的微信用户,蕴含着无限的商机。将企业微网站植入微信公众...