从零开始配置 vim(14)——目录管理插件

2022-09-22 17:03:46 浏览数 (1)

我们在介绍vim目录管理的时候提到 vim自带一个 叫做 netrw的工具来管理目录。但是它自身的功能有限,而且样式也丑。今天我们将使用其他强大的插件来替代 netrw,增强目录管理功能

nvim-tree 插件

安装使用

增强目录管理功能我们采用 nvim-tree 插件。根据对应文档的描述,我们可以使用如下代码进行安装

代码语言:javascript复制
use {
  'kyazdani42/nvim-tree.lua',
  requires = {
    'kyazdani42/nvim-web-devicons', -- optional, for file icons
  },
  tag = 'nightly' -- optional, updated every week. (see issue #1193)
}

安装完成之后我们新建一个文件 plugin-config/nvimtree.lua 用来保存它的配置信息。该文件中先写入以下内容用于加载启动 nvim-tree 插件

代码语言:javascript复制
require("nvim-tree").setup()

之后我们可以使用命令 :NvimTreeToggle 打开文件树,再次使用该命令可以关闭文件树。

打开之后我们发现一个问题,打开文件树之后,标签页仍然是居左对齐的。影响观看,我们应该让 tab 标签跟着往右移动一些距离。如何配置,我们可以在 bufferline 插件官方找到

代码语言:javascript复制
offsets = {
  {
    filetype = "NvimTree",
    text = "File Explorer",
    highlight = "Directory",
    text_align = "left"
  }
}

将这段代码添加到 bufferline.lua 的设置中,此时我们的 bufferline.lua 设置的代码应该变为如下这样

代码语言:javascript复制
require("bufferline").setup{
    options = {
        mode = "buffers",
        numbers = "ordinal",
        offsets = {
            {
                filetype = "NvimTree",
                text = "File Explorer",
                highlight = "Directory",
                text_align = "left"
            }
        }
    }
}

我们先映射一个快捷键,用于打开或者关闭文件树

代码语言:javascript复制
vim.api.nvim_set_keymap("n", "<F2>", ":NvimTreeToggle<CR>", {noremap = true, silent = true})

配置

我们可以对其进行一些配置,例如这里我不想它显示 .git 目录中的内容,但是想保留 .gitignore 的显示。我们可以使用如下配置

代码语言:javascript复制
require("nvim-tree").setup({
    -- 关闭文件时,自动关闭
    auto_close = true,
    filters = {
        -- 不显示 .git 目录中的内容
        custom = {
            ".git/"
        },
        -- 显示 .gitignore
        exclude = {
            ".gitignore"
        },
        -- 不显示隐藏文件
        dotfiles = true
    },
    -- 以图标显示git 状态
    git = {
        enable = true
    }
})

使用

我们使用该插件最大的目的不是为了显示目录的树形结构,而是为了快速管理文件,例如我们可以通过树快速打开、查找文件,甚至通过树快速创建、删除、移动、拷贝文件和目录

  • r:重命名文件或者目录
  • a:创建一个文件
  • d: 删除一个文件(需要最后确认)
  • x: 剪切一个文件到剪切板或者从剪切板移除一个剪切
  • c:拷贝一个文件到剪切板或者从剪切板移除一个拷贝
  • p: 粘贴文件或者目录

当然它还有其他许多快捷键,只是其他的我很少使用,所以这里就不列举了。如果你对这些快捷键不太满意,可以重新定义。

例如我们介绍 ntrw 的时候知道它也可以进行目录管理,为了减少记忆负担,你也可以采用 ntrw 的快捷键。我们在 setup 函数中添加如下代码

代码语言:javascript复制
view = {
  mappings = {
    list = {
      -- 定义快捷键
      {key = "%", action = "create"},
      {key = "d", action = "create"},
      {key = "R", action = "rename"},
      {key = "D", action = "remove"}
    }
  }
}

这里仅仅给大家做一个演示,我自己并不推荐采用这种方式。我更喜欢它原版的快捷键。另外从我的使用习惯来说,我在需要进行跳转的时候多数用的是标签、跳转到定义、gf甚至采用 :find 这种形式。使用它只是为了查看目录结构以及进行目录结构的管理。

0 人点赞