Neovim 插件 i18n.nvim 介绍

前言

最近一直在使用 Neovim 做 vue3 的开发,其中使用了 vue-i18n 作为国际化的解决方案,项目中有大量的国际化内容,需要统计管理、查询、提示。

正赶上最近 Vibe Coding 的概念比较火,就使用业务时间让 AI 帮忙写了这个国际化插件 yelog/i18n.nvim,主要功能有:

  1. 实时预览国际化key
  2. 国际化key的补全(集成 blink.cmp)
  3. 国际化key定义的跳转
  4. 国际化key不存在时提示 Diagnostic
  5. 国际化key的统计
  6. 国际化key的模糊搜索(集成 fzf.lua)

安装

推荐使用 layz.nvim 作为插件管理器,安装方式如下:

lua 复制代码
{
  'yelog/i18n.nvim',
  dependencies = {
    'ibhagwan/fzf-lua',
    'nvim-treesitter/nvim-treesitter'
  },
  config = function()
    require('i18n').setup({
      locales = { 'en', 'zh' },
      sources = {
        'src/locales/{locales}.json',
      }
    })
  end
}

其中 locales 作为你项目中的语言列表, sources 作为你项目中国际化文件的路径,{locales} 会被替换为 locales 中的语言列表。

sources 支持多个文件类型,变量路径等,具体可以参考 REAEDME#Use Case

使用介绍

实时预览国际化key

支持在国际化key使用的地方如 t('common.hello') 处,实时预览国际化内容。并且支持切换默认显示的语言,及是否显示国际化key

国际化key的补全

在国际化key使用的地方如 t('|') 的竖线出,会集成 blink.cmp 进行补全显示

国际化key定义的跳转

在国际化 Key 使用的地方如 t('common.hello') 处,按 gd 可以跳转到国际化 key 的定义处。

在国际化key的定义处,按 gd 可以跳转到其他语言的定义处

国际化key不存在时提示 Diagnostic

如果在国际化key使用的地方使用了不存在的key,如 t('common.hello1'),会有 Diagnostic 提示

国际化key的模糊搜索(集成 fzf.lua)

通过集成 fzf.lua 实现国际化key及默认语言翻译的模糊搜索。

支持 help 提示

在国际化key使用的地方如 t('common.hello') 处,按 <c-k> 可以查看帮助提示

最后

这个插件主要时为了满足自己的需求设计的,所以如何有任何建议和意见,欢迎提 issue

相关推荐
麦麦鸡腿堡1 小时前
Java的单例设计模式-饿汉式
java·开发语言·设计模式
哆啦A梦15881 小时前
点击Top切换数据
前端·javascript·vue.js
假客套1 小时前
Request method ‘POST‘ not supported,问题分析和解决
java
傻童:CPU1 小时前
C语言需要掌握的基础知识点之前缀和
java·c语言·算法
爱吃山竹的大肚肚1 小时前
@Valid校验 -(Spring 默认不支持直接校验 List<@Valid Entity>,需用包装类或手动校验。)
java·开发语言
雨夜之寂2 小时前
mcp java实战 第一章-第一节-MCP协议简介.md
java·后端
皮皮林5512 小时前
蚂蚁又开源了一个顶级 Java 项目!
java
小光学长2 小时前
基于Vue的2025年哈尔滨亚冬会志愿者管理系统5zqg6m36(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
吹晚风吧2 小时前
spring是如何解决循环依赖的(二级缓存不行吗)?
java·spring·循环依赖·三级缓存
九丶弟2 小时前
SpringBoot的cache使用说明
java·spring boot·spring·cache