首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

无法在类组件中调用React Hook "useTranslation“

基础概念

React Hooks 是 React 16.8 版本引入的新特性,允许你在函数组件中使用状态和其他 React 特性,而不需要编写类组件。useTranslation 是一个常用的 Hook,通常用于国际化和本地化项目,它来自于 react-i18next 库。

问题原因

在类组件中无法直接使用 Hooks,因为 Hooks 的设计初衷是为了在函数组件中使用。类组件有自己的生命周期方法和状态管理方式,而 Hooks 则是针对函数组件的。

解决方法

如果你需要在类组件中使用国际化功能,可以考虑以下几种解决方案:

1. 使用高阶组件(HOC)

你可以创建一个高阶组件来封装 useTranslation Hook,然后在类组件中使用这个高阶组件。

代码语言:txt
复制
import React from 'react';
import { useTranslation } from 'react-i18next';

const withTranslation = (Component) => {
  return class extends React.Component {
    render() {
      const { t } = useTranslation();
      return <Component {...this.props} t={t} />;
    }
  };
};

class MyComponent extends React.Component {
  render() {
    const { t } = this.props;
    return <div>{t('hello')}</div>;
  }
}

export default withTranslation(MyComponent);

2. 使用 render props

你可以创建一个组件,通过 render props 的方式将 useTranslation 的结果传递给类组件。

代码语言:txt
复制
import React from 'react';
import { useTranslation } from 'react-i18next';

class TranslationProvider extends React.Component {
  render() {
    const { t } = useTranslation();
    return this.props.children(t);
  }
}

class MyComponent extends React.Component {
  render() {
    return (
      <TranslationProvider>
        {({ t }) => <div>{t('hello')}</div>}
      </TranslationProvider>
    );
  }
}

export default MyComponent;

3. 转换为函数组件

如果可能的话,将类组件转换为函数组件是最简单的解决方案。

代码语言:txt
复制
import React from 'react';
import { useTranslation } from 'react-i18next';

const MyComponent = () => {
  const { t } = useTranslation();
  return <div>{t('hello')}</div>;
};

export default MyComponent;

参考链接

通过以上方法,你可以在类组件中实现国际化功能,而不必直接使用 useTranslation Hook。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • 【多角度】react中类组件与函数组件区别

    bug收集:专门解决与收集bug的网站 网址:www.bugshouji.com 常见面试题:react中类组件与函数组件的区别 常见的回答: 类组件有生命周期,函数组件没有 类组件需要继承 Class...FP(函数式编程),与数学中的函数思想类似,所以假定输入和输出存在某种关联的话,那么相同输入必定会有相同的输出 所以相对于类组件,函数组件会更加的纯粹,简单,更利于测试,这就是它们本质上的区别 2...在还没有 hooks 的时代,函数组件的能力是相对较弱的,在那个时候常常用高阶组件包裹函数组件模拟生命周期,当时流行的解决方案是 Recompose,在还没有 hooks 的时代,函数组件的能力是相对较弱的...使用场景 从上面的内容咱们能够总结出: 在不使用 Recompose 和 Hooks 的情况,如果需要使用生命周期,那么就用类组件,限定场景比较固定 但在 recompose 或 Hooks 的加持下,...设计模式 在设计模式上,类组件是可以实现继承的,而函数组件没有继承能力 但是在react中官方是不推荐使用继承的,因为继承的灵活性更差,细节屏蔽的过多,所以就有了 组合高于继承 的铁律 5.

    1.7K20

    美丽的公主和它的27个React 自定义 Hook

    前言 在上一篇git 原理中我们在「前置知识点」中随口提到了Hook。其中,就有我们比较熟悉的React Hook。 而针对React Hook而言,除了那些让人眼花缭乱的「内置hook」。...这意味着我们可以像下面的图像所示,「将一个或多个组件组合(使用)到另一个组件中」: 有状态组件 vs 无状态组件 在React中,组件可以是有状态(stateful)或无状态(stateless)的。...例如,用于获取数据并将数据管理在本地变量中的逻辑是有状态的。我们可能还希望在多个组件中重复使用获取数据的逻辑。 以前,状态逻辑只能在类组件中使用生命周期方法来实现。...这种方法确保了在所有组件中的一致性,而无需手动进行类的操作。...使用场景 我们可以在我们希望触发动画、延迟加载图像或在用户滚动时加载额外内容的情况下,使用这个Hook。 要使用这个钩子,首先将其导入到我们的组件文件中。

    70720

    基于 TS 的 React 模板项目,集成 eslint sass,采用 StandardJS 代码风格,包含自动注册组件等各项功能,新建项目或 React 学习必备

    我很不喜欢在 js 中写 css。所以,我在项目中构建了 style 文件夹,所有的 scss 文件均放在此处。然后在项目入口中加以引用,即可。...优点 使用简便,代码量少,引用多个组件时也只要 import 一条即可。 缺点 使用自动组件后,WebStorm 等 IDE 是无法通过你的引用自动跳转到该组件的。...某些组件可能已经不使用了,但是你也不想删了,可以将上面的 auto 部分给注释掉,在编译的时候,会自动摇树掉这个组件的(除非你又普通方式引用了-_-|||) 使用自动注册组件 在项目任意 tsx 文件中...使用 tsx 组件内使用 import React, { FC } from 'react' // 引用 useTranslation import { useTranslation } from 'react-i18next...此外,一些变量等,都可以在 @/style/config.scss 中配置。 建议,除入口scss文件外的所有 scss 文件名以 _ 下划线开头,表示该文件为组件文件,不需要独立编译。

    1.8K20

    在小程序中调用API在小程序中自定义弹窗组件

    因为业务需要在小程序里加上很多的弹窗,就想写一个组件来实现; #创建组件 新建文件夹component专门放组件, 新建popup页面,在popup.json中设置: { "component"...注意:在组件wxss中不应使用ID选择器、属性选择器和标签名选择器。...在子组件中自定义值是以小驼峰的形式书写的,但是在父组件传的时候要以“-”连接。...然后子组件关闭按钮监听onTap事件,点击子组件关闭按钮时,会通知父组件去改变状态) 逻辑: 在子组件中给要触发的元素加 bindtap = 'onTap' 然后通过在method中设置onTap函数...在onTap中的triggerEvent中设置要触发父组件事件的函数名称 父组件接收到字组件的消息,然后触发事件 具体参考:小程序-组件通信 子组件: wxml <view class="hide-btn

    3K20

    如何在 React Native 实现类微信小程序平台:WebView 调用原生组件

    在《我们是如何将 Cordova 应用嵌入到 React Native 中》 一文中,我们简单地介绍了『React Native 重写 Cordova 插件:复杂插件的调用』步骤: WebView 调用...RN 方法,并监听 React Native 返回的相应事件 React Native 接收到 WebView 的调用,调用原生代码,并监听原生代码返回的相应事件 原生代码执行 React Native...调用的方法,并响应事件给 React Native React Native 接收到原生代码的值,执行 injectJavaScript 注入代码到 WebView 里并执行 注入的 JavaScript...步骤2:React Native 接收到 WebView 的调用,调用原生代码,并监听原生代码返回的相应事件 在 WebView 的 onMessage 方法里,我们需要处理不同的 action: onMessage...Native 调用的方法,并响应事件给 React Native 如上,由于 iOS 的日期插件是异步的,并且它只能通过方法,而非组件的方式来唤醒 UI,故而需要 sendEventWithName

    3.6K100

    react中类组件传值,函数组件传值:父子组件传值、非父子组件传值

    父子组件传值、非父子组件传值; 类组件传值 父子 组件传值 子 传 父: 子组件:事件的触发 sendMsg=()=>{...: 父子组件传值 父传子: 1)在父组件中找对子标签,在子组件的标签上添加自定义属性,自定义属性名 = {要发送的数据} 2)在子组件模板中使用props.自定义属性名可以获取父组件传递过来的数据,同时在子组件的函数中接受一个参数 props function...} 子传父: 前提必须要有props,在函数组件的行參的位置,需要的是子组件的函数的props 1)在子组件中自定义一个数显进行数据发送,在需要出发的dom元素上面绑定自定义事件...msg,i) } } 非父子组件传值 函数组件中我们一般情况下使用useEffect实现数据的请求 // useEffect Hook 看做 componentDidMount,componentDidUpdate

    6.3K20

    「React进阶」我在函数组件中可以随便写 —— 最通俗异步组件原理

    首先先来看一下 jsx ,在 React JSX 中 代表 DOM 元素,而 代表组件, Index 本质是函数组件或类组件。...组件 Index 是 type 属性为类或者组件本身的 element 对象。...在 React 中 Susponse 是什么呢?那么正常情况下组件染是一气呵成的,在 Susponse 模式下的组件渲染就变成了可以先悬停下来。 首先解释为什么悬停?...render data:整个 render 过程都是同步执行一气呵成的,那样就会 组件 Render => 请求数据 => 组件 reRender ,但是在 Suspense 异步组件情况下允许调用 Render...那么对于如上情况,如果每一个页面组件,都加上 componentDidCatch 这样捕获错误,降级 UI 的方式,那么代码过于冗余,难以复用,无法把降级的 UI 从业务组件中解耦出来。

    3.8K30

    React + webpack 开发单页面应用简明中文文档教程(七)jsx 组件中调用组件、父组件给子组件传值

    React + webpack 开发单页面应用简明中文文档教程(七)jsx 组件中调用组件、父组件给子组件传值 在上一章中,我们成功调取数据,并渲染了一个列表。应该还是有成就感的吧。...创建 @/coms/header.jsx 组件 新建这个文件,并输入以下代码: import React, { Component } from 'react' export default class...我们去修改我们的 page/site/index.jsx 文件 父组件调用并传值给子组件 import React, { Component } from 'react' import { Link }...from 'react-router-dom' import Api from '@/tool/api.js' // 这样,调用我们的自定义的组件 import Header from '@/coms...如上,我们顺利的把值传给了子组件,并且子组件顺利的给显示出来了。

    1.1K10

    .Net调用Office Com组件的原理及问题:检索com类工厂组件检索 COM 类工厂中 CLSID 为 {XXX} 的组件失败

    component with CLSID {91493441-5A91-11CF-8700-00AA0060263B} failed due to the following error: 80040154 没有注册类...Server 2008 X64中通过.NET程序调用32位com组件的问题,按照其说的,在Visual Studio中,将编译的目标平台(Platform target)设置为:X86,然后重新统计发布项目...幻灯片】啊,原来服务器是64位了,没有加载32位的组件,运行中敲入mmc -32,在控制台中‘文件’‘添加/删除管理单元’选择‘组件服务’添加,就会出现【Microsoft Office PowerPoint...总结如下: .net调用office组件进行Excel、Word、ppt的一些操作,需要做一下操作: 1. 正确全面的安装office 2....Administrator、IIS-IUSRS()、Network Services、Network 、USERS),添加“启动和激活权限”、“访问权限”,并赋予本地启动和激活;-标识,交互式用户(不能选择启动用户,会无法结束进程

    5.1K20

    「React TS3 专题」使用 TS 的方式在类组件里定义事件

    在「React TS3 专题」亲自动手创建一个类组件,我们一起学习了如何用 TS 的方式在React 里定义类组件(class component)以及了解了什么是 JSX。...本篇文章,笔者将带着大家一起了解下如何使用 TS 的方式在 React 里定义类组件事件。... 我们点击按钮时就触发调用 handleOkClick 方法。...造成这样的问题是this不能指向我们当前组件的类,提示相关属性是未定义的,常用的解决方案,就是把这种函数改成箭头函数,利用箭头函数this的穿透性,就解决了,关于箭头函数的使用问题,笔者的这篇文章「ES6...小节 今天的文章我们就到这里,内容不是太多,我们一起学习了如何在React里使用TS的方法定义事件,以及使用箭头函数的方式进行事件方法的实现,接下来的文章,笔者将继续介绍,在React里如何用 TS 的方式定义

    2.4K20

    使用WebSocket在Server类中无法使用Autowired注解进行自动注入

    问题 在SpringBoot项目中使用WebSocket的过程中有其他的业务操作需要注入其它接口来做相应的业务操作,但是在WebSocket的Server类中使用Autowired注解无效,这样注入的对象就是空...,在使用过程中会报空指针异常。...注释:上面说的WebSocket的Server类就是指被@ServerEndpoint注解修饰的类 原因 原因就是在spring容器中管理的是单例的,他只会注入一次,而WebSocket是多对象的,当有新的用户使用的时候...WebSocket对象,这就导致了用户创建的WebSocket对象都不能注入对象了,所以在运行的时候就会发生注入对象为null的情况; 主要的原因就是Spring容器管理的方式不能直接注入WebSocket中的对象

    5.6K60

    Hooks概览(译)

    在函数组件中调用useState来向它添加一些本地state。React将在重新渲染之间保留此状态。useState返回一对值:当前 state 值和一个用于更新这个值的函数。...可以在事件处理程序或者其它地方调用这个函数。它类似于类中的this.setState。不同的是它不能将旧的state和新的state合并在一起。...Hooks是一个“钩住”React state和生命周期特性的函数组件。Hooks在类中不起作用——它们让你在没有类的情况下使用React。...我们将这些操作称为“副作用”(或简称为“影响”)(side effects),因为它们会影响其他组件,并且在渲染过程中无法完成。...实际上,每次调用Hook都是一个完全隔离的状态,所以你甚至可以在一个组件中两次调用相同的自定义Hook。 自定义Hooks更像是一种约定而非功能。

    1.8K90
    领券