之前我们定义了各种各样的快捷键,有为了增强功能自定义的,有针对插件的。数量一多有的时候就不那么容易记忆了。要是每次要去配置文件找我定义了哪些快捷键肯定会影响使用的。

本篇将要介绍一个插件,它是快捷键的一个词典,可以快速找到我们想要的快捷键

安装

使用 packer 的小伙伴可以使用如下代码进行安装

use {"folke/which-key.nvim"}

然后我们新键一个文件作为它的配置文件,并写入如下代码

require("which-key").setup({})

这个时候我们使用一些快捷键并且在中间停顿一下就可以看到它已经给出了相关的提示了

配置

默认的配置已经足够好了,基本不需要我们对它的行为做某些配置。它真正强大的地方在于,我们可以自己注册快捷键到显示中去。有时候不知道什么原因某些插件或者我们自定义的快捷键无法显示时可以使用这个方法注册到显示中。

假设我们现在有一个 <leader>ff 的键,它用来打开配置文件,但是它在 which-key 中没有显示出来,我们可以使用它的 register 方法来注册。该方法原型如下

register(mappings, opts)

它接收两个 table 参数,第一个表示需要注册的快捷键绑定,第二个是注册时的一些属性。

mappings 中的字段主要用来定义快捷键以及它的显示文字,后面我们通过例子来体会它的具体参数

opts 主要有下面几个参数

  • mode: 表示模式,与nvim_set_keymap第一个参数中的模式相同
  • prefix: 前置键,我们触发该条快捷键需要的前置键,一般使用leader作为前置键
  • buffer: 命令对应的缓冲区id,用它来指定这个绑定作用于某个局部缓冲区
  • silent: 同我们之间介绍的 nvim_set_keymap中的 silent含义
  • noremap: 快捷键不进行递归传递

接下来我们通过几个例子来体会它的用法

local wk = require("which-key")
wk.register({
f = {
name = "myvimrc", -- 指定该快捷键组的名称
f = {":edit $MYVIMRC<CR>", "Open vimrc"}, -- 创建新的快捷键绑定
s = {":source $MYVIMRC<CR>", "reload vimrc", noremap = true},
-- 也可以只显示一个标签而不绑定到具体的快捷键
e = {"New File"}
}
}, {prefix = "<leader>"})

通过上面的代码我们绑定了 <leader>ff<leader>fs<leader>fe 这三个快捷键。我们可以尝试一下执行 <leader>ff 发现它确实打开了我们的配置文件,而且我们稍微停顿一下它也给出了提示



我们将这个改写一下

wk.register({
["<leader>"] = {
f = {
name = "myvimrc", -- 指定该快捷键组的名称
f = {":edit $MYVIMRC<CR>", "Open vimrc"}, -- 创建新的快捷键绑定
s = {":source $MYVIMRC<CR>", "reload vimrc", noremap = true},
-- 也可以只显示一个标签而不绑定到具体的快捷键
e = {"New File"}
}
}
}, {silent = true, noremap = true})

或者也可以改写为这样

wk.register({
["<leader>f"] = {
name = "myvimrc",
f = { ":edit $MYVIMRC<CR>", "Open vimrc" },
s = { ":source $MYVIMRC<CR>", "reload vimrc", noremap = true },
n = { "New File" },
},
})
wk.register({
["<leader>f"] = { name = "myvimrc" },
["<leader>ff"] = { ":edit $MYVIMRC<CR>", "Open vimrc" },
["<leader>fs"] = { ":source $MYVIMRC<CR>", "reload vimrc", noremap = true },
["<leader>fn"] = { "New File" },
})

到这里相信各位小伙伴应该已经明白了如何使用 mappings这个字段,它外层是每次按下的按键,最内层则用来绑定具体的命令和提示时显示的具体内容。一般来说我们用不到这个东西,但是如果希望动态的修改这个显示的内容,例如把快捷键归类,这个就很有用了。

我们可以对照一下之前定义的快捷键,发现分屏相关的快捷键并没有显示出提示,这个时候我们就可以将它添加到对应的快捷键中

wk.register({
["s"] = {
name = "split window",
v = { ":vsp<CR>", "vertical split window" },
h = { ":sh<CR>", "horizontal split window"},
c = { ":close<CR>", "close this window"},
o = { ":only<CR>", "close all but this window"},
},
}, {noremap = true, silent = true})

如果你不喜欢它用英文显示,还可以尝试 将所有英文提示改为中文,这是一个浩大的工程,有兴趣的小伙伴可以尝试一下

查看所有快捷键绑定

有时候我们不知道某个功能具体绑定到哪个键上面了,甚至不知道它有这个快捷键绑定,这个时候可以使用 :WhichKey 这个命令来检查一下。它默认有2个参数

  • 第一个参数是一个字符串,查看所有以此字符串为开头的快捷键,例如使用 :WhichKey <leader>s 来查看所有以 <leader>s开头的快捷键
  • 第二个参数一个是表示模式的字符,用来限定它只显示绑定在某个模式中的快捷键,例如 :WhichKey<leader>s n 只显示在 normal 模式下的快捷键

好了,本篇的内容到此就结束了。

从零开始配置 vim(17)——快捷键提示的更多相关文章

  1. mac配置vim-go

    基本的设置信息(参考网址:http://hessian.cn/p/1026.html): "还是配置/.vimrc文件. syn on "语法支持 set laststatus=2 ...

  2. vim使用快捷键

    vim使用快捷键 索引 1. 关于Vim 1.1 Vim的几种模式 2. 启动Vim 3. 文档操作 4. 光标的移动 4.1 基本移动 4.2 翻屏 4.3 标记 5. 插入文本 5.1 基本插入 ...

  3. 从零开始配置TypeScript + React + React-Router + Redux + Webpack开发环境

    转载请注明出处! 说在前面的话: 1.为什么不使用现成的脚手架?脚手架配置的东西太多太重了,一股脑全塞给你,我只想先用一些我能懂的库和插件,然后慢慢的添加其他的.而且自己从零开始配置也能学到更多的东西 ...

  4. VIM常用快捷键(转载)

    移动光标 h,j,k,l 上,下,左,右 ctrl-e 移动页面 ctrl-f 上翻一页 ctrl-b 下翻一页 ctrl-u 上翻半页 ctrl-d 下翻半页 w 跳到下一个字首,按标点或单词分割 ...

  5. 【vim环境配置】在centos6.4上配置vim的一些零碎记录

    上一篇日志已经step by step地实录了如何在本机mac上配置vim开发环境已经各种插件. 有了一定经验之后,开始在实验室远程server上centos6.4的环境下配置vim环境. 这台机器是 ...

  6. 为Python配置Vim编辑器(GUI/非GUI皆可)

    原文地址:https://blog.csdn.net/alanzjl/article/details/49383943 Vim as a python IDE ** 最近一直在写Python,但一直没 ...

  7. [转帖]VIM常用快捷键

    VIM常用快捷键 https://www.cnblogs.com/markleaf/p/7808817.html 快捷键能够显著的提高工作效率 一.移动光标 h,j,k,l 上,下,左,右ctrl-e ...

  8. Mac 配置 vim

    Mac 配置 vim 安装 vim 7.4 cd ~ hg clone https://code.google.com/p/vim/ cd vim ./configure --with-feature ...

  9. Vim命令快捷键(网摘)

    Vim命令快捷键(网摘) 原文出处:[?---->home]

  10. 一些常用的vim编辑器快捷键:

    一些常用的vim编辑器快捷键: h」.「j」.「k」.「l」,分别控制光标左.下.上.右移一格. 按「ctrl」+「b」:屏幕往“后”移动一页. 按「ctrl」+「f」:屏幕往“前”移动一页. 按「c ...

随机推荐

  1. 自然语言处理 Paddle NLP - 机器同传技术及应用-理论

    基础 自然语言处理(NLP) 自然语言处理PaddleNLP-词向量应用展示 自然语言处理(NLP)-前预训练时代的自监督学习 自然语言处理PaddleNLP-预训练语言模型及应用 自然语言处理Pad ...

  2. VS 2019 目标框架中看不到 Net Core 3.X

    VS 2019 目标框架中没有 .NET Core 3.X..Net 5.0 https://dotnet.microsoft.com/download/dotnet-core/3.0 Visual ...

  3. 给科研人的 ML 开源发布工具包

    什么是开源发布工具包? 恭喜你的论文成功发表,这是一个巨大的成就!你的研究成果将为学界做出贡献. 其实除了发表论文之外,你还可以通过发布研究的其他部分,如代码.数据集.模型等,来增加研究的可见度和采用 ...

  4. Google C++编程规范(Google C++ Style Guide)

    参考链接: Google 代码规范 C++总结 Google 开源项目风格指南--中文版 Google C++ Style Guide是一份不错的C++编码指南,我制作了一张比较全面的说明图,可以在短 ...

  5. 【Logging 日志库】Cpp 日志库 boost::log 以及 glog 的对比

    日志能方便地诊断程序原因.统计程序运行数据,是大型软件系统必不可少的组件之一.本文将从设计上和功能上对比 C++ 语言常见的两款日志库: boost::log 和 google-glog . 设计 b ...

  6. Spring 学习笔记(2)框架介绍

    本篇文章主要对 Spring 框架进行整体介绍,包括其核心功能模块与体系结构,让大家对该框架有个大体的认识. 1. 前景提要 如果你之前学过 Servlet 的话,那么一定会对 MVC 分层概念有所了 ...

  7. 如何做一次完美的 ABTest?

    本文首发于 vivo互联网技术 微信公众号 链接:https://mp.weixin.qq.com/s/mO5MdwG7apD6RzDhFwZhog作者:DuZhimin 越来越多的公司都在尝试 AB ...

  8. debian更新openssh 9.6

    先更新一下,然后安装libssl-dev zlib1g-dev依赖文件 apt update apt install build-essential apt-get install -y libssl ...

  9. python之数学函数应用

    一.abs(x) 1.作用: 函数返回 x(数字)的绝对值,如果参数是一个复数,则返回它的大小(模) 2.举例说明: #1.abs() a = abs(-15) print(a) b = abs(1+ ...

  10. 理解 docker volume

    1. docker volume 简介 文章 介绍了 docker image,它由一系列只读层构成,通过 docker image 可以提高镜像构建,存储和分发的效率,节省时间和存储空间.然而 do ...