防止在React Native的页面加载中调用多个Const

Prevent calling multiple Const in Page loading in React Native

提问人:Mohoshin 提问时间:10/9/2023 更新时间:10/9/2023 访问量:28

问:

这是我的代码:

    const Home = ({route}) => {

      const drawerTag = route.params.drawerTag; //drawer Menu Tag History
      const dropDownLabel = route.params.dropDownLabel; // For GE0 Dropdown Header

      // All Variables for use
      const [Geovalue, setValueGeo] = useState(null); // for selected Geo
      const [plvalue, setValuePl] = useState(null); // for selected PL
      const [isFocus, setIsFocus] = useState(false); // focused ? not focused
      const [geoList, setGeoList] = useState(null); //Geo List
      const [plList, setPlList] = useState(null); //PL List
      const [plDetailsInfo, setplDetailsInfo] = useState(null); //PL List
      const [DataTable, setTableData] = useState(null);


      // After Page load Function call
      useEffect(() => {
        function fetchData() {
          getGeoInfo(drawerTag,7424);
          renderLabel('jhn');
        }
        fetchData();
      }, [drawerTag]);


      // All Accesible Geo List
      const getGeoInfo = async (drawerTag, gpID) =>{

        try{

            const response = await fetch("https://hello2/Models/get_pl_data.php?gpID="+gpID+"&drawerTag="+drawerTag);
            
            const userData = await response.json();

            const geoList = userData.geo_list;
            const plList = userData.plList;
            const plinfo = userData.plDetails;

            setGeoList(geoList); //set Geo List 
            setValueGeo(geoList[0]["MARKET_NAME"]); // Set Selected Value
            setPlList(plList);
            setValuePl(plList[0]["PL_LIST"]);
            setplDetailsInfo(plinfo[0]);

            console.log(plList[0]["PL_LIST"]+"PLH11");

            console.log(geoList[0]["MARKET_NAME"]+"GEO11");
            console.log(plinfo[0]);


        }
        catch(error){

            console.log(error);

        }
      };




      // Label of the Select Box
      const renderLabel =  (selectTitle) => {

        console.log("Label dropdown");
        
          return (
            <Text style={[styles.label, {color: 'white'} ]}>
              {selectTitle}
            </Text>
          );

      };

      const renderPlList =  (plList) => {  

        console.log("PL dropdown");

        if(plList && plList.length){
          return(
            <View style={styles.container}>
              {renderLabel("PL List")}
              <Dropdown
                style={[styles.dropdown, isFocus && { borderColor: 'white' }]}
                placeholderStyle={styles.placeholderStyle}
                selectedTextStyle={styles.selectedTextStyle}
                inputSearchStyle={styles.inputSearchStyle}
                iconStyle={styles.iconStyle}
                data={plList}
                search
                maxHeight={300}
                labelField="PL_LIST"
                valueField="PL_LIST"
                placeholder={plList[0]["PL_LIST"]}
                searchPlaceholder="Search..."
                value={plList}
                onFocus={() => setIsFocus(true)}
                onBlur={() => setIsFocus(false)}
                onChange={item => {
                  setValueGeo(item.PL_LIST);
                  setIsFocus(false);
                }}
                renderLeftIcon={() => (
                  <AntDesign
                    style={styles.icon}
                    color={isFocus ? '#19AAF8' : 'white'}
                    name="Safety"
                    size={20}
                  />
                )}
              />
            </View>
            
          );
        }
        else{
          return(
            <View style={styles.container}>
              <Text style={styles.errorMsg}>No PL Info</Text>
            </View>
          );
        }
      };

    const renderPLDetails = (plDetails) => {

      console.log(plDetails+"Hello 1");
      if (plDetails && plDetails.length) {
      
      const tableDetails =  {

        tableHead: ['DATE', 'LAST HOUR', 'CUM HOUR'],
        tableData: [
            [plDetails["D0"], plDetails["PL_HITS_LH"], plDetails["PL_HITS_CUM"]],
            [plDetails["D1"], plDetails["PL_HITS_LH_D1"], plDetails["PL_HITS_CUM_D1"]],
            [plDetails["D2"], plDetails["PL_HITS_LH_D2"], plDetails["PL_HITS_CUM_D2"]],
            [plDetails["D7"], plDetails["PL_HITS_LH_D7"], plDetails["PL_HITS_CUM_D7"]],
        ],
      };



    console.log(tableDetails);


      return (
        <View style={styles.containerTable}>
                <Table borderStyle={{ borderWidth: 4, borderColor: 'teal' }}>
                    <Row data={DataTable.tableHead} style={styles.headTable} textStyle={styles.headText} />
                    <Rows data={DataTable.tableData} textStyle={styles.textTable} />
                </Table>
        </View>
      );
    }
    else{
      return(
        <View style={styles.container}>
          <Text style={styles.errorMsg}>No Table Info</Text>
        </View>
      );
    }

    };

    if (geoList && geoList.length) {
      return(
        <ScrollView style={styles.mainContainer}>
            <View style={styles.container}>
              {renderLabel(dropDownLabel+" List")}
              <Dropdown
                style={[styles.dropdown, isFocus && { borderColor: 'white' }]}
                placeholderStyle={styles.placeholderStyle}
                selectedTextStyle={styles.selectedTextStyle}
                inputSearchStyle={styles.inputSearchStyle}
                iconStyle={styles.iconStyle}
                data={geoList}
                search
                maxHeight={300}
                labelField="MARKET_NAME"
                valueField="MARKET_NAME"
                placeholder={geoList[0]["MARKET_NAME"]}
                searchPlaceholder="Search..."
                value={geoList}
                onFocus={() => setIsFocus(true)}
                onBlur={() => setIsFocus(false)}
                onChange={item => {
                  
                  setValueGeo(item.MARKET_NAME);
                  // setIsFocus(false);
                }}
                renderLeftIcon={() => (
                  <AntDesign
                    style={styles.icon}
                    color={isFocus ? '#19AAF8' : 'white'}
                    name="Safety"
                    size={20}
                  />
                )}
              />
            </View>   
            {renderPlList(plList)}
            {renderPLDetails(plDetailsInfo)}
        </ScrollView>
        );
      }
      else{
        return(
          <View style={styles.container}>
            <Text style={styles.errorMsg}>No Geo Info</Text>
          </View>
        );
      }
    }

问题是,每次我运行应用程序时,除了 getGeoInfo() 之外,所有常量都会自动运行。我想在getGeoInfo()运行后一个一个地加载const,

而且,当我专注于下拉页面时,会自动提交,并且再次运行。有什么可以帮助我的吗?

react-native 自动加载

评论


答:

1赞 Similoluwa Odeyemi 10/9/2023 #1

你的问题不是很清楚,但是 像这样更改你的 useEffect:

   useEffect(() => {
    const fetchData = async() => {
      await getGeoInfo(drawerTag,7424);
      renderLabel('jhn');
    }
    fetchData();
  }, [drawerTag]);

评论

0赞 Mohoshin 10/9/2023
在我的应用程序中开始运行,所有常量都在加载。但是我想在页面加载后调用所有常量。比如:页面加载成功后 getGeoInfo() -> renderPlList() -> renderPLDetails() ,这将是运行序列