Skip to content

Latest commit

 

History

History
74 lines (55 loc) · 2.33 KB

migrating-v9-to-v10.md

File metadata and controls

74 lines (55 loc) · 2.33 KB

Migrating v9 to v10

v10 is a complete rewrite, taking the chance to clean up some complexity added from v1 to v9.

This means you will need to test your application more cautiously before release.

{% hint style="info" %} This is a specific migration guide regarding the complete react-i18next rewrite in v10.
If you're looking for general release notes, please have a look in the CHANGELOG file. {% endhint %}

New in v10

The most obvious change is the hook function for use inside functional components:

import React from 'react';
import { useTranslation } from 'react-i18next';

export function MyComponent() {
  const [t, i18n] = useTranslation();

  return <p>{t('my translated text')}</p>
}

Components without replacement

The Interpolation component (which was marked as deprecated for a long time and replaced by the Trans Component) was removed finally. You will need to replace it with the Trans Component.

Migration

Replace your components like described below. If you don't have to use Suspense in your existing App you can set useSuspense: false in react.init options.react:

i18n.init({
  react: {
    useSuspense: false
  }
});

I18nextProvider changes

The I18nextProvider no longer provides as many properties as before. Make the necessary changes in your codebase after migrating.

// New props
{
  i18n,
  defaultNS,
}

// Old props
{
  i18n,
  defaultNS,
  reportNS,
  lng: i18n && i18n.language,
  t: i18n && i18n.t.bind(i18n),
}

Components v9 -> v10

Type <= v7 (v8) v9 (v8) v10
hook - useTranslation
HOC translate withNamespaces withTranslation
render prop I18n NamespacesConsumer Translation
i18next plugin reactI18nextModule reactI18nextModule initReactI18next
Provider I18nextProvider I18nextProvider I18nextProvider
Complex Translation Trans Trans Trans
Interpolations Interpolate Interpolate Trans