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

相关推荐
LoveEate3 分钟前
vue3 el-switch表单联动校验
前端·javascript·vue.js
2301_7976042414 分钟前
d40: vue杂项问题
前端·javascript·vue.js
编啊编程啊程19 分钟前
gRPC从0到1系列【6】
java·rpc·kafka·dubbo·nio
Olrookie1 小时前
若依前后端分离版学习笔记(十八)——页面权限,页签缓存以及图标,字典,参数的使用
vue.js·笔记·学习
宸津-代码粉碎机1 小时前
Redis 进阶:跳出缓存局限!7 大核心场景的原理与工程化实践
java·人工智能·redis·python
极客先躯1 小时前
Spring Statemachine 架构详解
java·spring·架构
ccccczy_1 小时前
Java微服务容器化与 Kubernetes 编排实战:从 Docker 多阶段构建到云原生弹性扩展
java·docker·kubernetes·springboot·microservices·cloudnative·containerization
琹箐1 小时前
Aupload + vuedraggable实现 上传的文件可以拖拽排序
前端·vue.js
前端 贾公子1 小时前
Vue.js props mutating:反模式如何被视为一种良好实践。
前端·javascript·vue.js
沉木渡香2 小时前
VSCode中Java开发环境配置的三个层级(Windows版)1-3
java·windows·vscode