React - How to export a pure stateless component

2020-05-16 13:00发布

How can I export a stateless pure dumb component?

If I use class this works:

import React, { Component } from 'react';

export default class Header extends Component {
    render(){
        return <pre>Header</pre>
    }
}

However if I use a pure function I cannot get it to work.

import React, { Component } from 'react';
export default const Header = () => {
    return <pre>Header</pre>
}

Am I missing something basic?

4条回答
Rolldiameter
2楼-- · 2020-05-16 13:34

You can also use a function declaration instead of assignment:

export default function Header() {
    return <pre>Header</pre>
}

In your example, you already use curly brackets and return so this is apparently matching with your needs with no compromise.

查看更多
我欲成王,谁敢阻挡
3楼-- · 2020-05-16 13:40

Just as a side note. You could technically export default without declaring a variable first.

export default () => (
  <pre>Header</pre>
)
查看更多
虎瘦雄心在
4楼-- · 2020-05-16 13:59

ES6 doesn't allow export default const. You must declare the constant first then export it:

const Header = () => {
  return <pre>Header</pre>
};
export default Header;

This constraint exists to avoid writting export default a, b, c; that is forbidden: only one variable can be exported as default

查看更多
我欲成王,谁敢阻挡
5楼-- · 2020-05-16 13:59

you can do it in two ways

1)

// @flow

type ComponentAProps = {
  header: string
};

const ComponentA = (props: ComponentAProps) => {
  return <div>{props.header}</div>;
};

export default ComponentA;

2)

// @flow

type ComponentAProps = {
  header: string
};

export const ComponentA = (props: ComponentAProps) => {
  return <div>{props.header}</div>;
};

if we use default we import like this

import ComponentA from '../shared/componentA'

if we don't use default we import like this

import { ComponentA } from '../shared/componentA'
查看更多
登录 后发表回答