fzf-tab

fzf-tab

使用 fzf 优化 Zsh 命令行补全的插件

fzf-tab 是一个 Zsh 插件,它利用 fzf 替代默认补全菜单,提供多项选择、组切换和连续补全等功能。该插件展示默认补全系统的结果,适用范围广泛,并保留大部分原有配置。fzf-tab 支持多种插件管理器,还提供二进制模块以提升性能。通过优化命令行补全体验,fzf-tab 为用户带来更高效的 Zsh 使用体验。

fzf-tabZsh命令行补全插件自定义Github开源项目

fzf-tab

CI GitHub license

使用fzf替换zsh的默认补全选择菜单!

asciicast

目录

安装

[!重要]

  1. 确保已安装fzf
  2. fzf-tab需要在compinit之后加载,但要在会包装小部件的插件之前加载,如zsh-autosuggestionsfast-syntax-highlighting
  3. 补全应该在compinit之前配置,正如zsh-completions手动安装指南中所述。

手动安装

首先,克隆此仓库。

git clone https://github.com/Aloxaf/fzf-tab ~/somewhere

然后在您的~/.zshrc中添加以下行。

autoload -U compinit; compinit source ~/somewhere/fzf-tab.plugin.zsh

Antigen

antigen bundle Aloxaf/fzf-tab

Zinit

zinit light Aloxaf/fzf-tab

Oh-My-Zsh

将此仓库克隆到您的自定义目录,然后将fzf-tab添加到您的插件列表中。

git clone https://github.com/Aloxaf/fzf-tab ${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/fzf-tab

Prezto

将此仓库克隆到您的contrib目录,然后在.zpreztorc中将fzf-tab添加到您的模块列表中。

git clone https://github.com/Aloxaf/fzf-tab $ZPREZTODIR/contrib/fzf-tab

使用

像往常一样按<kbd>Tab</kbd>键即可~

可用的按键绑定:

  • <kbd>Ctrl</kdb>+<kdb>Space</kbd>:选择多个结果,可通过fzf-bindings标签配置

  • <kbd>F1</kbd>/<kbd>F2</kbd>:在组之间切换,可通过switch-group标签配置

  • <kbd>/</kbd>:触发连续补全(在补全深层路径时很有用),可通过continuous-trigger标签配置

可用的命令:

  • disable-fzf-tab:禁用fzf-tab并回退到compsys

  • enable-fzf-tab:启用fzf-tab

  • toggle-fzf-tab:切换fzf-tab的状态。这也是一个zle小部件。

配置

常见的配置如下:

# 在补全`git checkout`时禁用排序 zstyle ':completion:*:git-checkout:*' sort false # 设置描述格式以启用组支持 # 注意:这里不要使用转义序列,fzf-tab会忽略它们 zstyle ':completion:*:descriptions' format '[%d]' # 设置list-colors以启用文件名着色 zstyle ':completion:*' list-colors ${(s.:.)LS_COLORS} # 强制zsh不显示补全菜单,这允许fzf-tab捕获无歧义的前缀 zstyle ':completion:*' menu no # 在补全cd时使用eza预览目录内容 zstyle ':fzf-tab:complete:cd:*' fzf-preview 'eza -1 --color=always $realpath' # 使用`<`和`>`切换组 zstyle ':fzf-tab:*' switch-group '<' '>'

Tmux

如果您使用的是tmux >= 3.2,我们提供了一个脚本ftb-tmux-popup来充分利用其"弹出"功能。

zstyle ':fzf-tab:*' fzf-command ftb-tmux-popup

顺便说一下,您也可以在fzf-tab之外使用这个脚本。

ls | ftb-tmux-popup

asciicast

更多信息,请参见Wiki#Configuration

二进制模块

默认情况下,如果您设置了list-colors标签,fzf-tab会使用zsh-ls-colors来解析和应用ZLS_COLORS。

然而,这是一个纯zsh脚本,如果您有太多文件需要着色,它会变得很慢。 fzf-tab附带了一个二进制模块来加速这个过程。您可以使用build-fzf-tab-module构建它,然后它会自动启用。

与其他插件的区别

fzf-tab不执行"补全",它只是向您展示默认补全系统的结果。

因此它可以在任何地方工作(变量、函数名、目录栈、单词内补全等)。 而且您对默认补全系统的大部分配置仍然有效。

与其他插件的兼容性

一些插件可能也会将"^I"绑定到它们的自定义小部件,比如fzf/shell/completion.zshohmyzsh/lib/completion.zsh

默认情况下,fzf-tab会调用之前绑定到"^I"的小部件来获取补全列表。所以在大多数情况下没有问题,除非fzf-tab在一个未正确处理先前绑定的插件之前初始化。

因此,如果您发现fzf-tab无法正常工作,请确保它是最后一个绑定"^I"的插件(如果您不明白我的意思,只需将它放到插件列表的末尾)。

相关项目

编辑推荐精选

扣子-AI办公

扣子-AI办公

职场AI,就用扣子

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

堆友

堆友

多风格AI绘画神器

堆友平台由阿里巴巴设计团队创建,作为一款AI驱动的设计工具,专为设计师提供一站式增长服务。功能覆盖海量3D素材、AI绘画、实时渲染以及专业抠图,显著提升设计品质和效率。平台不仅提供工具,还是一个促进创意交流和个人发展的空间,界面友好,适合所有级别的设计师和创意工作者。

图像生成热门AI工具AI图像AI反应堆AI工具箱AI绘画GOAI艺术字堆友相机
码上飞

码上飞

零代码AI应用开发平台

零代码AI应用开发平台,用户只需一句话简单描述需求,AI能自动生成小程序、APP或H5网页应用,无需编写代码。

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

Refly.AI

Refly.AI

最适合小白的AI自动化工作流平台

无需编码,轻松生成可复用、可变现的AI自动化工作流

酷表ChatExcel

酷表ChatExcel

大模型驱动的Excel数据处理工具

基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。

AI工具使用教程AI营销产品酷表ChatExcelAI智能客服
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

热门AI工具生产力协作转型TraeAI IDE
AIWritePaper论文写作

AIWritePaper论文写作

AI论文写作指导平台

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

数据安全AI助手热门AI工具AI辅助写作AI论文工具论文写作智能生成大纲
博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

热门AI工具AI办公办公工具智能排版AI生成PPT博思AIPPT海量精品模板AI创作
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

下拉加载更多