之前我们对neovim
进行了基础的配置,这篇主要介绍我比较常用的快捷键配置。到这篇开始我们的配置已经可以为两个大的模块——基础配置和快捷键配置。我们的目录也应该按照模块来进行组织。在正式配置之前让我们先规划一下目录结构。
当前我打算采用如下的目录格式
~/.config/nvim
├── lua
│ ├── basic.lua # 用来存储基础配置
│ ├── keybindings.lua # 用来存储快捷键配置
└── init.lua # 配置文件入口,主要用来加载其他配置文件
lua模块加载
还记得我们之前介绍过的 runtime
吗?在介绍文件类型的时候说过,runtime
有两个路径,一个是系统路径位于 $VIMRUNTIME
中,第二个就是用户配置文件路径,可以使用$MYVIMRC
来查看。在 Unix/Linux
平台,它位于 ~/.config/nvim
中,而模块路径就位于 runtime/lua
中。
在 lua
语言中,加载模块可以使用 require()
。它传入一个不带 .lua
后缀的模块的相对路径。所以这里想要在 init.lua
中加载基础配置和 快捷键配置可以使用如下语句
require('basic')
require('keybindings')
如果目录有多层,例如要加载 lua/basic/settings.lua
模块的话,可以使用 .
或者 /
来组织路径。
require('basic/settings')
这里我推荐使用 /
。主要是为了使用 gf
快速跳转到对应路径。使用 .
的话 gf
并不会将它解析为目录结构,而是直接去找名为 basic.settings.lua
的文件。
我们先创建好所有目录和文件,然后将之前的 init.lua
拷贝一份到 lua/basic.lua
中,并且创建文件 lua/keybindings.lua
。然后修改 init.lua
。
require("basic")
require("keybinds")
快捷键配置
这里我们事先设置 path路径,然后使用 gf快速跳转到不同文件。
我们首先来设置 leader 键和 localleader键
vim.g.mapleader = " "
vim.g.maplocalleader = " "
下面我们按照 《vim从嫌弃到依赖》这系列文章中介绍的顺序来配置快捷键
标签页快捷键
由于我自身很少用 标签页的功能,而且vim中自带的命令已经够高效的了,所以这里我基本没怎么定义快捷键
-- 配置tabline快捷键,主要以 t开头代表 t
-- 关闭当前标签页
vim.api.nvim_set_keymap("n", "tc", ":tabclose<cr>", {noremap = true, silent = true})
-- 关闭所有标签页,仅保留当前标签页
vim.api.nvim_set_keymap("n", "to", ":tabonly<cr>", {noremap = true, silent = true})
-- gt 切换到下一个,gT切换到上一个
翻页
代码翻页我主要采用 Ctrl + f和 Ctrl + b,代表 Foward 和 Backup。这里为了方便我将它们分别向上或者向下移动 10行。同时将光标至于中间位置,有时候光标在下面不好看它的上下文。
vim.api.nvim_set_keymap("n", "<C-f>", "10jzz", {noremap = true, silent = true})
vim.api.nvim_set_keymap("n", "<C-b>", "10kzz", {noremap = true, silent = true})
多窗口相关的操作
多窗口快捷键我将它分为两个部分,一个是窗口本身的操作,主要是打开和关闭。第二个是窗口间跳转。第一类操作我采用 s
(split
)最为开头,第二类以 <leader>
键开头。
-- 多窗口的打开与关闭
vim.api.nvim_set_keymap("n", "sv", ":vsp<CR>", {noremap = true, silent = true})
vim.api.nvim_set_keymap("n", "sh", ":sp<CR>", {noremap = true, silent = true})
vim.api.nvim_set_keymap("n", "sc", ":close<CR>", {noremap = true, silent = true})
vim.api.nvim_set_keymap("n", "so", ":only<CR>", {noremap = true, silent = true})
-- 多窗口跳转
vim.api.nvim_set_keymap("n", "<leader>h", "<C-w>h", {noremap = true, silent = true})
vim.api.nvim_set_keymap("n", "<leader>l", "<C-w>l", {noremap = true, silent = true})
vim.api.nvim_set_keymap("n", "<leader>j", "<C-w>j", {noremap = true, silent = true})
vim.api.nvim_set_keymap("n", "<leader>k", "<C-w>k", {noremap = true, silent = true})
其他有用的绑定
这里我们将之前文章中用来当做例子的一部分比较有用的映射放上去
-- 其他有用的绑定
-- 使用 <C-u> 将光标所在单词转化为全大写
vim.api.nvim_set_keymap("i", "<C-u>", "<esc>viwUwa", {noremap = true, silent = true})
-- 使用 <C-l> 将光标所在单词转化为全小写
vim.api.nvim_set_keymap("i", "<C-l>", "<esc>viwuwa", {noremap = true, silent = true})
-- dw删除当前光标所在单词
vim.api.nvim_set_keymap("n", "dw", "diw", {noremap = true, silent = true})
-- 快速打开vimrc文件
vim.api.nvim_set_keymap("n", "<leader>ee", ":vs $MYVIMRC<CR>", {noremap = true, silent = true})
-- 快速启用 vimrc
vim.api.nvim_set_keymap("n", "<leader>ss", "source $MYVIMRC<CR>", {noremap = true, silent = true})
本篇到这里就结束了,下一篇我们将要来介绍插件管理的相关内容,敬请期待