Skip to content

Releases: intlify/vue-i18n

v9.5.0

29 Sep 02:39
Compare
Choose a tag to compare

What's Changed

🌟 Features

πŸ› Bug Fixes

  • Handle falsy values in i18n.te() by @BuuBux in #1554
  • fix(core-base): wrong list index resolving on jit optimization by @kazupon in #1571
  • fix: support runtime module for node.js by @kazupon in #1573

πŸ“οΈ Documentations

🍭 Examples

  • Update nuxt.config.ts in Nuxt 3 Minimal Starter Example by @ram-you in #1553

New Contributors

Full Changelog: v9.4.1...v9.5.0

v9.4.1

14 Sep 10:51
Compare
Choose a tag to compare

What's Changed

πŸ› Bug Fixes

πŸ“οΈ Documentations

Full Changelog: v9.4.0...v9.4.1

v9.4.0

11 Sep 10:08
Compare
Choose a tag to compare

What's Changed

🌟 Features

  • feat(shared): support dist package for browser by @kazupon in #1527

πŸ› Bug Fixes

  • fix(vue-i18n-bridge): peer dependency warning by @kazupon in #1536

⚑ Improvement Features

  • feat(core): optimize core package for node.js by @kazupon in #1530
  • fix: optimize tree-shaking for devtools packages by @kazupon in #1531
  • improvement: tweak compler registration and message condition on compile function by @kazupon in #1532

New Contributors

Full Changelog: v9.3.0...v9.4.0

v9.3.0

05 Sep 08:39
Compare
Choose a tag to compare

We are excited to announce the release of Vue I18n v9.3, finally !! This release includes some new features, bug fixes, improvements, and document fixes.

We had commited with 37 contributors. Thanks for your contributing ❀️

In the following, we introduce some of the new features:

🌟 Features

Node.js Dual packages (cjs / mjs)

We provide CommonJS and Native ESM dual module packages for Node.js. This supports both require and import for loading modules in Node.js.

JIT Style Compilation

Supports JIT (Just In Time) style compilation of message formats. This mean, removes the CSP limitation and allows for use in environments such as Service worker, Web worker, and Edge.

It mean also now supports the use-case where locale messages are dynamically retrieved from the backend via the API.

For more information, please see the docs

The performance of JIT-style compilation is close to that of conventional AOT (Ahead Of Time) style compilation, and you can improve the performance to nearly 3x with combination of JIT + AOT.

Below are the compile performance benchmark results for vue-i18n:

> node ./benchmark/index.mjs

compilation:

compile simple message x 396,898 ops/sec Β±0.31% (98 runs sampled)
compile complex message x 60,036 ops/sec Β±0.34% (99 runs sampled)

simple pattern on 1000 resources (AOT):

resolve time with core x 279,919 ops/sec Β±0.19% (99 runs sampled)
resolve time on composition x 93,963 ops/sec Β±0.48% (93 runs sampled)
resolve time on composition with compile cache x 230,928 ops/sec Β±0.20% (100 runs sampled)

simple pattern on 1000 resources (JIT):

resolve time with core x 277,813 ops/sec Β±0.18% (99 runs sampled)
resolve time on composition x 91,959 ops/sec Β±0.43% (97 runs sampled)
resolve time on composition with compile cache x 227,117 ops/sec Β±0.15% (99 runs sampled)

simple pattern on 1000 resources (JIT + AOT):

resolve time with core x 319,061 ops/sec Β±0.18% (100 runs sampled)
resolve time on composition x 204,529 ops/sec Β±0.22% (95 runs sampled)
resolve time on composition with compile cache x 204,652 ops/sec Β±0.30% (100 runs sampled)

complex pattern on 1000 resources (AOT):

resolve time with core x 240,427 ops/sec Β±0.37% (100 runs sampled)
resolve time on composition x 33,959 ops/sec Β±0.45% (94 runs sampled)
resolve time on composition with compile cache x 200,980 ops/sec Β±0.15% (99 runs sampled)

complex pattern on 1000 resources (JIT):

resolve time with core x 225,739 ops/sec Β±0.25% (99 runs sampled)
resolve time on composition x 36,379 ops/sec Β±0.49% (97 runs sampled)
resolve time on composition with compile cache x 191,653 ops/sec Β±0.24% (100 runs sampled)

complex pattern on 1000 resources (JIT + AOT):

resolve time with core x 278,542 ops/sec Β±0.20% (98 runs sampled)
resolve time on composition x 92,781 ops/sec Β±0.31% (98 runs sampled)
resolve time on composition with compile cache x 92,865 ops/sec Β±0.33% (98 runs sampled)

You can clone Vue I18n and run the benchmark with pnpm build:type && pnpm benchmark to check.

Custome message format

Starting with v9.3, Vue I18n will give message format customization as an experimental feature. This will allow for extending to the message format:

import { createI18n } from 'vue-i18n'
import { messageCompiler } from './compilation'

const i18n = createI18n({
  legacy: false,
  locale: 'en',
  messageCompiler,
  messages: {
    en: {
      hello: 'hello world!',
      greeting: 'hi, {name}!',
      photo: `You have {numPhotos, plural,
        =0 {no photos.}
        =1 {one photo.}
        other {# photos.}
      }`
    }
  }
})

About details, please see the docs

  • feat: support custom message format with messageCompiler option by @kazupon in #1497
  • perf: support drop message compiler feature flag by @kazupon in #1510

Exports type definition and API

Export v-t type definitions and API $te to support Vue I18n extending for third vendors and your Vue applications.

❗ Important Changes: 1

allowComposition option

The allowComposition option will be removed in Vue I18n v10. We have accordingly output a warning if you are using it.

If you are using Vue I18n Legacy API to migrate to the Composition API, please make sure you have done so with the Vue I18n v9 version.

  • fix: prepare to drop allowComposition option by @kazupon in #1496

Deprecate vue-i18n official bundle plugins

The following plugin or loader for bundler is deprecated because it can be replaced by the unplugin-vue-i18n.

These will only be taken as hot fixes in the future, and no additional functionality will be added.

⚑ Improvement Features: 15

πŸ› Bug Fixes: 17

  • fix(message-compiler): linked modifier breaks with parenthesis by @kazupon in #1506
  • fix(core-base): isMessageAST more strictly by @kazupon in #1509
  • fix: root context message availability for linked messages in SFCs on production by @kazupon in #1477
  • fix: cleanup global injection resources by @kazupon in #1479
  • fix: conditional exports order for message compiler by @kazupon in #1461
  • fix: allow AST on rt by @kazupon in #1455
  • fix: JIT compilation on runtime only by @kazupon in #1451
  • fix: reslove with caml-case for components by @kazupon in #1418
  • fix: crash of the app when we mix flat json keys by @kazupon in #1419
  • fix: Resolve the message in components which was rendered with slots, for about <i18n-t>, <i18n-n> and <i18n-d> by @kazupon in #1416
  • fix: isPlainObject incorrectly identifies objects wrapped in a Proxy object in Safari 10 by @reed-soul in #1379
  • fix: useI18n wrong type and other type broken by @kazupon in #1309
  • fix: generate ComponentCustomProperties d.ts by @kazupon in #1306
  • fix: avoid VueI18n extending on root by @kazupon in #1241
  • fix: multiple VueI18n extending by @kazupon in #1239
  • fix: tree-shaking Fragment with for vue-i18n-bridge by @kazupon in #1187
  • fi...
Read more

v9.3.0-beta.27

30 Aug 04:08
Compare
Choose a tag to compare

What's Changed

🌟 Features

  • feat: support custom message format with messageCompiler option by @kazupon in #1497
  • perf: support drop message compiler feature flag by @kazupon in #1510
  • feat: export v-t directive type by @kazupon in #1511

πŸ› Bug Fixes

  • fix(message-compiler): linked modifier breaks with parenthesis by @kazupon in #1506
  • fix(core-base): isMessageAST more strictly by @kazupon in #1509

πŸ“οΈ Documentations

  • docs: add vite-plugin-vue-i18n support vite version to warning notice by @regchiu in #1499

πŸ‘• Refactoring

Full Changelog: v9.3.0-beta.26...v9.3.0-beta.27

v9.3.0-beta.26

16 Aug 08:13
Compare
Choose a tag to compare
v9.3.0-beta.26 Pre-release
Pre-release

What's Changed

⚑ Improvement Features

πŸ“οΈ Documentations

πŸ‘• Refactoring

  • fix: drop componentInstanceCreatedListener by @kazupon in #1495

New Contributors

Full Changelog: v9.3.0-beta.25...v9.3.0-beta.26

v9.3.0-beta.25

02 Aug 04:56
Compare
Choose a tag to compare

What's Changed

🌟 Features

πŸ› Bug Fixes

  • fix: root context message availability for linked messages in SFCs on production by @kazupon in #1477
  • fix: cleanup global injection resources by @kazupon in #1479

πŸ“οΈ Documentations

  • Add example code for deployed app for nuxt3-app-vue-i18n by @lyqht in #1469
  • Fix #1475: Typo in documentation when referring to translation component by @ducksblock in #1476

New Contributors

Full Changelog: v9.3.0-beta.24...v9.3.0-beta.25

v9.3.0-beta.24

08 Jul 18:08
Compare
Choose a tag to compare

What's Changed

πŸ› Bug Fixes

  • fix: conditional exports order for message compiler by @kazupon in #1461

Full Changelog: v9.3.0-beta.23...v9.3.0-beta.24

v9.3.0-beta.23

08 Jul 15:38
Compare
Choose a tag to compare

What's Changed

🌟 Features

Full Changelog: v9.3.0-beta.22...v9.3.0-beta.23

v9.3.0-beta.22

07 Jul 01:25
Compare
Choose a tag to compare

What's Changed

πŸ› Bug Fixes

πŸ“ˆ Performance Fixes

Full Changelog: v9.3.0-beta.21...v9.3.0-beta.22