wrapper.instance() 和wrapper.find(Component).instance() 返回 null

发布于 2025-01-09 00:49:57 字数 920 浏览 1 评论 0原文

考虑下面的代码。

    const wrapper = mount(
            <Provider store={store}>
                <BrowserRouter>
                    <ComponentPage/>
                </BrowserRouter>
            </Provider>,
        );
    
    wrapper.instance() // null
    wrapper.find(ComponentPage).instance() //null   ('ComponentPage') or (<ComponentPage/>) //null
    wrapper.children().first().children().first().children().first().instance() //null
    

但是 wrapper.name() // Providerwrapper.find(ComponentPage).name() //ComponentPage

如何获取实例来测试以下代码.

test.only('test 1', () => { 
           const app = wrapper.render().find(ComponentPage);
           app.instance().getComponents = jest.fn(); //instance null
           expect(app.instance().getComponents).toHaveBeenCalled();
        });

consider the below code.

    const wrapper = mount(
            <Provider store={store}>
                <BrowserRouter>
                    <ComponentPage/>
                </BrowserRouter>
            </Provider>,
        );
    
    wrapper.instance() // null
    wrapper.find(ComponentPage).instance() //null   ('ComponentPage') or (<ComponentPage/>) //null
    wrapper.children().first().children().first().children().first().instance() //null
    

However wrapper.name() // Provider and wrapper.find(ComponentPage).name() //ComponentPage

How to get the instance to test the below code.

test.only('test 1', () => { 
           const app = wrapper.render().find(ComponentPage);
           app.instance().getComponents = jest.fn(); //instance null
           expect(app.instance().getComponents).toHaveBeenCalled();
        });

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

落花随流水 2025-01-16 00:49:57

来自 .instance() =>; ReactComponent 文档:

返回单节点包装器的节点的底层类实例;这在它的方法中。它必须是单节点包装器。

注意:在 React 16 及更高版本中,instance() 对于无状态功能组件返回 null。

例如

index.tsx:

import React from 'react';

export function FunctionComponent() {
  return <div>function component</div>;
}

export class ClassComponent extends React.Component {
  render() {
    return <div>class component</div>;
  }
}

index.test.tsx:

import { mount } from 'enzyme';
import React from 'react';
import { Provider } from 'react-redux';
import { BrowserRouter } from 'react-router-dom';
import { createStore } from 'redux';
import { ClassComponent, FunctionComponent } from '.';

const store = createStore(() => {});

describe('71204270', () => {
  test('instance is null for function component', () => {
    const wrapper = mount(
      <Provider store={store}>
        <BrowserRouter>
          <FunctionComponent />
        </BrowserRouter>
      </Provider>
    );

    console.log(wrapper.find(FunctionComponent).instance());
  });

  test('instance is class instance ', () => {
    const wrapper = mount(
      <Provider store={store}>
        <BrowserRouter>
          <ClassComponent />
        </BrowserRouter>
      </Provider>
    );

    console.log(wrapper.find(ClassComponent).instance());
  });
});

测试结果:

 PASS  stackoverflow/71204270/index.test.tsx (10.179 s)
  71204270
    ✓ instance is null for function component (49 ms)
    ✓ instance is class instance  (9 ms)

  console.log
    null

      at Object.<anonymous> (stackoverflow/71204270/index.test.tsx:20:13)

  console.log
    <ref *1> ClassComponent {
      props: {},
      context: {},
      refs: {},
      updater: {
        isMounted: [Function: isMounted],
        enqueueSetState: [Function: enqueueSetState],
        enqueueReplaceState: [Function: enqueueReplaceState],
        enqueueForceUpdate: [Function: enqueueForceUpdate]
      },
      _reactInternalFiber: <ref *2> FiberNode {
        tag: 1,
        key: null,
        elementType: [class ClassComponent extends Component],
        type: [class ClassComponent extends Component],
        stateNode: [Circular *1],
        return: FiberNode {
          tag: 10,
          key: null,
          elementType: [Object],
          type: [Object],
          stateNode: null,
          return: [FiberNode],
          child: [Circular *2],
          sibling: null,
          index: 0,
          ref: null,
          pendingProps: [Object],
          memoizedProps: [Object],
          updateQueue: null,
          memoizedState: null,
          dependencies: null,
          mode: 0,
          effectTag: 0,
          nextEffect: null,
          firstEffect: null,
          lastEffect: null,
          expirationTime: 0,
          childExpirationTime: 0,
          alternate: null,
          actualDuration: 0,
          actualStartTime: -1,
          selfBaseDuration: 0,
          treeBaseDuration: 0,
          _debugID: 161,
          _debugIsCurrentlyTiming: false,
          _debugSource: null,
          _debugOwner: [FiberNode],
          _debugNeedsRemount: false,
          _debugHookTypes: null
        },
        child: FiberNode {
          tag: 5,
          key: null,
          elementType: 'div',
          type: 'div',
          stateNode: [HTMLDivElement],
          return: [Circular *2],
          child: null,
          sibling: null,
          index: 0,
          ref: null,
          pendingProps: [Object],
          memoizedProps: [Object],
          updateQueue: null,
          memoizedState: null,
          dependencies: null,
          mode: 0,
          effectTag: 0,
          nextEffect: null,
          firstEffect: null,
          lastEffect: null,
          expirationTime: 0,
          childExpirationTime: 0,
          alternate: null,
          actualDuration: 0,
          actualStartTime: -1,
          selfBaseDuration: 0,
          treeBaseDuration: 0,
          _debugID: 165,
          _debugIsCurrentlyTiming: false,
          _debugSource: null,
          _debugOwner: [Circular *2],
          _debugNeedsRemount: false,
          _debugHookTypes: null
        },
        sibling: null,
        index: 0,
        ref: null,
        pendingProps: {},
        memoizedProps: {},
        updateQueue: {
          baseState: null,
          baseQueue: null,
          shared: [Object],
          effects: null
        },
        memoizedState: null,
        dependencies: null,
        mode: 0,
        effectTag: 1,
        nextEffect: null,
        firstEffect: null,
        lastEffect: null,
        expirationTime: 0,
        childExpirationTime: 0,
        alternate: null,
        actualDuration: 0,
        actualStartTime: -1,
        selfBaseDuration: 0,
        treeBaseDuration: 0,
        _debugID: 163,
        _debugIsCurrentlyTiming: false,
        _debugSource: null,
        _debugOwner: null,
        _debugNeedsRemount: false,
        _debugHookTypes: null
      },
      _reactInternalInstance: {},
      state: null
    }

      at Object.<anonymous> (stackoverflow/71204270/index.test.tsx:32:13)

Test Suites: 1 passed, 1 total
Tests:       2 passed, 2 total
Snapshots:   0 total
Time:        10.634 s, estimated 12 s

From the .instance() => ReactComponent doc:

Returns the single-node wrapper's node's underlying class instance; this in its methods. It must be a single-node wrapper.

NOTE: With React 16 and above, instance() returns null for stateless functional components.

E.g.

index.tsx:

import React from 'react';

export function FunctionComponent() {
  return <div>function component</div>;
}

export class ClassComponent extends React.Component {
  render() {
    return <div>class component</div>;
  }
}

index.test.tsx:

import { mount } from 'enzyme';
import React from 'react';
import { Provider } from 'react-redux';
import { BrowserRouter } from 'react-router-dom';
import { createStore } from 'redux';
import { ClassComponent, FunctionComponent } from '.';

const store = createStore(() => {});

describe('71204270', () => {
  test('instance is null for function component', () => {
    const wrapper = mount(
      <Provider store={store}>
        <BrowserRouter>
          <FunctionComponent />
        </BrowserRouter>
      </Provider>
    );

    console.log(wrapper.find(FunctionComponent).instance());
  });

  test('instance is class instance ', () => {
    const wrapper = mount(
      <Provider store={store}>
        <BrowserRouter>
          <ClassComponent />
        </BrowserRouter>
      </Provider>
    );

    console.log(wrapper.find(ClassComponent).instance());
  });
});

Test result:

 PASS  stackoverflow/71204270/index.test.tsx (10.179 s)
  71204270
    ✓ instance is null for function component (49 ms)
    ✓ instance is class instance  (9 ms)

  console.log
    null

      at Object.<anonymous> (stackoverflow/71204270/index.test.tsx:20:13)

  console.log
    <ref *1> ClassComponent {
      props: {},
      context: {},
      refs: {},
      updater: {
        isMounted: [Function: isMounted],
        enqueueSetState: [Function: enqueueSetState],
        enqueueReplaceState: [Function: enqueueReplaceState],
        enqueueForceUpdate: [Function: enqueueForceUpdate]
      },
      _reactInternalFiber: <ref *2> FiberNode {
        tag: 1,
        key: null,
        elementType: [class ClassComponent extends Component],
        type: [class ClassComponent extends Component],
        stateNode: [Circular *1],
        return: FiberNode {
          tag: 10,
          key: null,
          elementType: [Object],
          type: [Object],
          stateNode: null,
          return: [FiberNode],
          child: [Circular *2],
          sibling: null,
          index: 0,
          ref: null,
          pendingProps: [Object],
          memoizedProps: [Object],
          updateQueue: null,
          memoizedState: null,
          dependencies: null,
          mode: 0,
          effectTag: 0,
          nextEffect: null,
          firstEffect: null,
          lastEffect: null,
          expirationTime: 0,
          childExpirationTime: 0,
          alternate: null,
          actualDuration: 0,
          actualStartTime: -1,
          selfBaseDuration: 0,
          treeBaseDuration: 0,
          _debugID: 161,
          _debugIsCurrentlyTiming: false,
          _debugSource: null,
          _debugOwner: [FiberNode],
          _debugNeedsRemount: false,
          _debugHookTypes: null
        },
        child: FiberNode {
          tag: 5,
          key: null,
          elementType: 'div',
          type: 'div',
          stateNode: [HTMLDivElement],
          return: [Circular *2],
          child: null,
          sibling: null,
          index: 0,
          ref: null,
          pendingProps: [Object],
          memoizedProps: [Object],
          updateQueue: null,
          memoizedState: null,
          dependencies: null,
          mode: 0,
          effectTag: 0,
          nextEffect: null,
          firstEffect: null,
          lastEffect: null,
          expirationTime: 0,
          childExpirationTime: 0,
          alternate: null,
          actualDuration: 0,
          actualStartTime: -1,
          selfBaseDuration: 0,
          treeBaseDuration: 0,
          _debugID: 165,
          _debugIsCurrentlyTiming: false,
          _debugSource: null,
          _debugOwner: [Circular *2],
          _debugNeedsRemount: false,
          _debugHookTypes: null
        },
        sibling: null,
        index: 0,
        ref: null,
        pendingProps: {},
        memoizedProps: {},
        updateQueue: {
          baseState: null,
          baseQueue: null,
          shared: [Object],
          effects: null
        },
        memoizedState: null,
        dependencies: null,
        mode: 0,
        effectTag: 1,
        nextEffect: null,
        firstEffect: null,
        lastEffect: null,
        expirationTime: 0,
        childExpirationTime: 0,
        alternate: null,
        actualDuration: 0,
        actualStartTime: -1,
        selfBaseDuration: 0,
        treeBaseDuration: 0,
        _debugID: 163,
        _debugIsCurrentlyTiming: false,
        _debugSource: null,
        _debugOwner: null,
        _debugNeedsRemount: false,
        _debugHookTypes: null
      },
      _reactInternalInstance: {},
      state: null
    }

      at Object.<anonymous> (stackoverflow/71204270/index.test.tsx:32:13)

Test Suites: 1 passed, 1 total
Tests:       2 passed, 2 total
Snapshots:   0 total
Time:        10.634 s, estimated 12 s
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文