首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >是否有自动锁定react组件的快速方法

是否有自动锁定react组件的快速方法
EN

Stack Overflow用户
提问于 2020-09-28 03:40:32
回答 3查看 260关注 0票数 1

我有大量需要简单模拟版本的react组件。

目前,对于每个组件,我必须创建一个新的mock文件夹,然后为该组件创建一个文件,然后为该组件创建一个新的简化版本。

代码语言:javascript
复制
├── models
│   ├── __mocks__
│   │   └── componentA.js
│   │   └── componentB.js
│   │   └── componentC.js
│   └── componentA.js
│   └── componentB.js
│   └── componentC.js

我模拟的每个文件看起来都是这样的:

代码语言:javascript
复制
import React from 'react';

const ComponentA = ({
}) => (
  <div>
    Mocked ComponentA
  </div>
);
export default ComponentA;

这会导致大量的额外工作和重复的代码。

有没有一种方法可以使用Jest自动锁定工具来自动实现上述功能。

我尝试使用以下命令,但它返回了babel错误:

代码语言:javascript
复制
const ReactCMock = (name) => ({
  __esModule: true,
  default: (props) => (
    <div className={name}>
      {name}
    </div>
  ),
});

jest.mock('./componentA', ReactCMock('Component A'));

错误:babel-plugin-jest-hoist: The second argument of `jest.mock` must be an inline function.

EN

Stack Overflow用户

回答已采纳

发布于 2020-09-28 04:43:08

尝试使用function声明定义MockReactC (请参阅the comment below),使其在jest.mock()调用之前被提升,并将对MockReactC()的调用包装在箭头函数中:

代码语言:javascript
复制
function MockReactC(name) {
  return {
    __esModule: true,
    default: (props) => (
      <div className={name}>
        {name}
      </div>
    ),
  };
}

jest.mock('./componentA', () => MockReactC('Component A'));
票数 2
EN
查看全部 3 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64092579

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档