用于流类型的React容器中的useSelector

时间:2020-03-12 13:22:58

标签: reactjs react-redux react-hooks flowtype

我来自普通的javascript世界,现在我不得不用钩子重写一个类组件,但是我在流程方面遇到了一些问题,从未使用过。

我有一个要使用钩子重写的功能组件,但是我无法使这些选择器起作用:

type Props = {
  history: Object,
  sets: Array<Object>,
  tArray: Object,
  gu: Object
};

const Page = () => {

  const { tArray} = useSelector<Object>(state => state.t.tArray.map(x => ({
    A: x.A,
    B: x.B,
    C: x.C
    date: x.lastExportDate
      ? dateFormat(new Date(x.lastExportDate), 'm/dd/yyyy')
      : []
  })))

  const { gu } = useSelector(state => state.gu)
  const { sets } = useSelector(state => state.sets.allSets.map(x=> ({
    value: x.setId,
    label: x.name
  })))

  const [showModal, setShowModal] = useState(false);

  return (
    <div>
    </div>
  )

}


export default HomePage;

我不知道如何编写选择器的返回类型以及容器收到的道具。

编写选择器的前两种方法都不起作用。

谢谢

1 个答案:

答案 0 :(得分:0)

这将起作用:

const { gu } = useSelector(state)
const { sets } = useSelector(state => state.sets.allSets.map(x=> {
  return {
    sets: {
      value: x.setId,
      label: x.name
   }
  }))

返回值应包含构造所需的内容。因此,第一个构造gu无关,因为状态拥有gu对象本身。第二个构造所需的sets对象没有返回所需的对象。


基本上,我想说的是:

假设我们有一个对象-

const obj = { foo: 1 }

现在,如果我们要构造foo以获得价值:

const { foo } = obj.foo // wrong
const { foo } = obj // right

我希望这对您来说很清楚。