React Native + Typescript:如何在堆栈屏幕组件中使用toggleDrawer?

问题描述 投票:0回答:1

我的问题很简单:navData的类型应该是什么?

我想从堆栈屏幕组件的标题切换抽屉,但是Typescript抱怨,因为navData.navigation上不存在toggleDrawer,因为该组件是堆栈屏幕组件。我想避免执行navData: any,那么好的类型应该是什么?

import React from "react";
import { View, Text, Platform } from "react-native";
import {
  NavigationStackScreenComponent,
  NavigationStackOptions
} from "react-navigation-stack";
import { HeaderButtons, Item } from "react-navigation-header-buttons";
import CustomHeaderButton from "../../components/UI/HeaderButton";

const ProductsOverviewScreen: NavigationStackScreenComponent = props => {
  return (
    <View>
      <Text>ProductsOverviewScreen</Text>
    </View>
  );
};

ProductsOverviewScreen.navigationOptions = (
  navData // What is the type?
): NavigationStackOptions => {
  return {
    headerTitle: "All Products",
    headerLeft: () => (
      <HeaderButtons HeaderButtonComponent={CustomHeaderButton}>
        <Item
          title="Menu"
          iconName={Platform.OS === "android" ? "md-menu" : "ios-menu"}
          onPress={() => navData.navigation.toggleDrawer()}
        />
      </HeaderButtons>
    ),
    headerRight: () => (
      <HeaderButtons HeaderButtonComponent={CustomHeaderButton}>
        <Item
          title="Cart"
          iconName={Platform.OS === "android" ? "md-cart" : "ios-cart"}
          onPress={() => navData.navigation.navigate({ routeName: "Cart" })}
        />
      </HeaderButtons>
    )
  };
};

export default ProductsOverviewScreen;
javascript reactjs typescript react-native react-navigation
1个回答
0
投票

一种快速而肮脏的方法可能是对其进行一些微调,以便您可以键入函数本身,而不仅仅是道具:ProductsOverviewScreen.navigationOptions: NavigationStackScreenComponent["navigationOptions"] = (navData) =>...。但不能保证它会工作。

一个更好的选择是,如果可以的话,从库中导入正确的道具(如果文档中没有运气的话,请检查仓库并查看导出的类型供您使用)。

© www.soinside.com 2019 - 2024. All rights reserved.