Heim >Web-Frontend >js-Tutorial >Kaskadierende Form React Native Advanced

Kaskadierende Form React Native Advanced

DDD
DDDOriginal
2024-12-08 13:00:181003Durchsuche

Ich möchte meine drei Ansätze zum Umgang mit kaskadierenden Formularfeldern teilen.

  1. Der erste Ansatz ist allgemein und verwendet Zustandsvariablen.
  2. Zweitens besteht darin, gewöhnliche Variablen und eine boolesche Zustandsvariable zu verwenden, um den Zustandseffekt auszulösen (Seite aktualisieren).
  3. Drittens gibt es dynamische Formularfelder mit gewöhnlichen Variablen.

Dies ist der dritte Ansatz und wir werden uns mit dynamischen Formularfeldern befassen.

Beachten Sie, dass Sie diesen Beitrag leichter verstehen, wenn Sie sich die beiden vorherigen Ansätze ansehen.

Erster Ansatz, Cascade Form Basic
Zweiter Ansatz, Kaskadenform verbessert

Lasst uns beginnen,

Inhalt

  • Grundform
  • Formularfelder-Objekt
  • Dynamische Feldwiedergabe
  • Beispieldaten
  • OnPage-Laden
  • Land laden
  • OnChange
  • Ladezustand
  • Ladepause (Stadt, Dorf, Straße)
  • Validierung
  • Formular zurücksetzen

Grundform

Dies ist eine statische Formularseite mit 5 Dropdown-Feldern.

import React, { useState, useEffect } from "react";
import { ScrollView, View, Text, StyleSheet, TouchableOpacity } from "react-native";
import { Dropdown } from "react-native-element-dropdown";
import { Snackbar } from "react-native-paper";

var snackMsg = "";
export default function App() {
  const [refreshPage, setRefreshPage] = useState(false);
  const [visible, setVisible] = useState(false);

  const onToggleSnackBar = () => setVisible(!visible);
  const onDismissSnackBar = () => setVisible(false);

  const resetForm = () => {
  };

  return (
    <ScrollView>



<p>refreshPage state variable is used to refresh the page in all the situations. </p>

<p><img src="https://img.php.cn/upload/article/000/000/000/173363402014343.jpg" alt="Cascading Form React Native Advanced" /></p>

<p>Now, These fields are going to be converted as dynamic. </p>

<h3>
  
  
  Form Field Object
</h3>

<p>Previously we had 3 separate objects for 3 different fields, but here all fields data placed under one form field object.<br>
</p>

<pre class="brush:php;toolbar:false"> . . .
const formFields = {
  country: {
    fieldId: "country",
    label: "Country",
    labelField: "name",
    valueField: "countryId",
    parents: [],
    list: [],
    selectedItem: {},
    selectedValue: null,
    onValueSelected: () => null,
  },
  state: {
    fieldId: "state",label: "State",labelField: "name",valueField: "stateId",
    parents: ["country"],list: [],selectedItem: {},selectedValue: null,
    onValueSelected: () => null,
  },
  city: {
    fieldId: "city",label: "City",labelField: "name",valueField: "cityId",
    parents: ["country", "state"],list: [],selectedItem: {},
    selectedValue: null,onValueSelected: () => null,
  },
  village: {
    fieldId: "village",label: "Village",labelField: "name",
    valueField: "villageId",
    parents: ["country", "state", "city"],
    list: [],selectedItem: {},selectedValue: null,
    onValueSelected: () => null,
  },
  street: {
    fieldId: "street",label: "Street",labelField: "name",
    valueField: "streetId",
    parents: ["country", "state", "city", "village"],
    list: [],selectedItem: {},selectedValue: null,onValueSelected: () => null,
  },
};

 . . .
export default function App() {
   . . .
}

Alle diese Eigenschaften eines Feldes haben Vorteile und sind für die dynamische Darstellung nützlich.

  • fieldId ID des Feldes
  • label Diaplay-Name des Feldes
  • labelField bezeichnet das Dropdown-Beschriftungsfeld in einem Dropdown-Listen-Array
  • valueField bezeichnet das Dropdown-Wertfeld
  • parent-Array von übergeordneten Feldern, wird für Validierungen verwendet
  • Listen-Dropdown-Listen-Array
  • selectedItem gesamtes ausgewähltes Elementobjekt des Dropdowns
  • selectedValue ausgewählter Wert
  • onValueSelected ist eine Funktionseigenschaft, die verwendet/aufgerufen wird, wenn ein Dropdown-Wert ausgewählt/geändert wird. Ursprünglich als leere Methode zugewiesen.

Dynamisches Feld-Rendering

Durch die Iteration der Formularfeldobjektschlüssel rendern wir Dropdown-Felder dynamisch, alle erforderlichen Eigenschaften sind im Formularfeldobjekt verfügbar.

export default function App() {
  . . .
    return (
    <View>



<p>handle focus / blur<br>
</p>

<pre class="brush:php;toolbar:false">var focusField = "";
export default function App() {
. . .

 const changeFocusField = (fld = "") => {
  focusField = fld;
  setRefreshPage(!refreshPage);
 };
. . .
}
<ZDropDown
. . .
  isFocus={focusField === ele}
  onFocus={() => {
    changeFocusField(ele);
  }}
  onBlur={() => changeFocusField("")}
  onChange={(item) => {}}
 />

Beispieldaten

Beispieldaten für die Felder Land, Bundesland, Stadt, Dorf und Straße.

const listCountry = [
  { countryId: "1", name: "india" },
  { countryId: "2", name: "uk" },
  { countryId: "3", name: "canada" },
  { countryId: "4", name: "us" },
];

const listSate = [
  { stateId: "1", countryId: "1", name: "state1_india" },
  { stateId: "4", countryId: "2", name: "state1_uk" },
  { stateId: "7", countryId: "3", name: "state1_canada" },
  { stateId: "10", countryId: "4", name: "state1_us" },
];

const listCity = [
  { cityId: "1", stateId: "1", countryId: "1", name: "city1_state1_country1" },
  { cityId: "5", stateId: "2", countryId: "1", name: "city5_state2_country1" },
  {
    cityId: "21",stateId: "7",countryId: "3",name:"city21_state7_country3",
  },
  {
    cityId: "26",stateId: "9",countryId: "3",name: "city26_state9_country3",
  },
];

const listVillage = [
  { cityId: "1", villageId: "1", name: "village 1  city 1" },
  { cityId: "2", villageId: "5", name: "village 5  city 2" },
  { cityId: "3", villageId: "9", name: "village 9  city 3" },
  { cityId: "4", villageId: "10", name: "village 10  city 4" },
];

const listStreet = [
  { villageId: "1", streetId: "1", name: "village 1 street 1" },
  { villageId: "1", streetId: "109", name: "village 1 street 109" },
  { villageId: "2", streetId: "2", name: "village 2 street 2" },
  { villageId: "2", streetId: "110", name: "village 2 street 110" },
];
 . . .
export default function App() {
  . . .
}
 . . .

OnPage-Laden

Zuerst müssen wir auf der Funktionalitätsseite einige wichtige Dinge einrichten. Denken Sie daran, dass wir der Eigenschaft onValueSelected eine leere Methode zugewiesen haben. Jetzt ist es an der Zeit, die eigentliche Methode zuzuweisen. Wir müssen also 5 Methoden erstellen und diese dem jeweiligen Formularfeld zuweisen.

export default function App() {
  . . .
  const allValuesSelected = () => {
    console.log("All fields value selected");
  };

  const loadStreet = async () => {};

  const loadVillage = async () => {};

  const loadCity = async () => {};

  const loadState = async () => {};

  const loadCountry = async () => {};

  const loadPageData = () => {
    formFields.country.onValueSelected = loadState;
    formFields.state.onValueSelected = loadCity;
    formFields.city.onValueSelected = loadVillage;
    formFields.village.onValueSelected = loadStreet;
    formFields.street.onValueSelected = allValuesSelected;    
  };

  return (. . .);
}

Wenn der Länderwert ausgewählt wird, muss die STATE-Liste geladen werden. Aus diesem Grund wird hier die Methode „loadState“ dem onValueSelected des Landes zugewiesen. Und ebenso andere Methoden zugewiesen.

  useEffect(() => {
    loadPageData();
  }, []);

  return (. . .);

Land laden

Länderliste aus Beispieldaten laden und beim ersten Laden der Seite aufrufen.

  const loadCountry = async () => {
    formFields.country.list = [...listCountry];
    setRefreshPage(!refreshPage);
  };

  const loadPageData = () => {
    formFields.country.onValueSelected = loadState;
    formFields.state.onValueSelected = loadCity;
    formFields.city.onValueSelected = loadVillage;
    formFields.village.onValueSelected = loadStreet;
    formFields.street.onValueSelected = allValuesSelected;

    loadCountry();
  };

OnChange

Wenn der Dropdown-Feldwert ausgewählt ist, müssen wir den entsprechenden Formularfeldwert einrichten, den Fokus entfernen und die nächste Dropdown-Liste laden.

return (
  . . .
  <ZDropDown
    // . . .
    onChange={(item) => {
      fld.selectedItem = item;
      fld.selectedValue = item[fld.valueField];
      focusField = "";
      fld.onValueSelected();
    }}
  />
  . . .
);

onValueSelected ist nützlich, oder?

Ladezustand

Wenn sich das erste Dropdown-Menü (Land) ändert, werden auch die übrigen Felder geändert. Daher müssen die Liste und die Daten aller anderen Formularfelder gelöscht werden. Dazu schreiben wir eine Methode, die die Werte vom angegebenen Feld bis zum Endfeld löschen kann.

import React, { useState, useEffect } from "react";
import { ScrollView, View, Text, StyleSheet, TouchableOpacity } from "react-native";
import { Dropdown } from "react-native-element-dropdown";
import { Snackbar } from "react-native-paper";

var snackMsg = "";
export default function App() {
  const [refreshPage, setRefreshPage] = useState(false);
  const [visible, setVisible] = useState(false);

  const onToggleSnackBar = () => setVisible(!visible);
  const onDismissSnackBar = () => setVisible(false);

  const resetForm = () => {
  };

  return (
    <ScrollView>



<p>refreshPage state variable is used to refresh the page in all the situations. </p>

<p><img src="https://img.php.cn/upload/article/000/000/000/173363402014343.jpg" alt="Cascading Form React Native Advanced" /></p>

<p>Now, These fields are going to be converted as dynamic. </p>

<h3>
  
  
  Form Field Object
</h3>

<p>Previously we had 3 separate objects for 3 different fields, but here all fields data placed under one form field object.<br>
</p>

<pre class="brush:php;toolbar:false"> . . .
const formFields = {
  country: {
    fieldId: "country",
    label: "Country",
    labelField: "name",
    valueField: "countryId",
    parents: [],
    list: [],
    selectedItem: {},
    selectedValue: null,
    onValueSelected: () => null,
  },
  state: {
    fieldId: "state",label: "State",labelField: "name",valueField: "stateId",
    parents: ["country"],list: [],selectedItem: {},selectedValue: null,
    onValueSelected: () => null,
  },
  city: {
    fieldId: "city",label: "City",labelField: "name",valueField: "cityId",
    parents: ["country", "state"],list: [],selectedItem: {},
    selectedValue: null,onValueSelected: () => null,
  },
  village: {
    fieldId: "village",label: "Village",labelField: "name",
    valueField: "villageId",
    parents: ["country", "state", "city"],
    list: [],selectedItem: {},selectedValue: null,
    onValueSelected: () => null,
  },
  street: {
    fieldId: "street",label: "Street",labelField: "name",
    valueField: "streetId",
    parents: ["country", "state", "city", "village"],
    list: [],selectedItem: {},selectedValue: null,onValueSelected: () => null,
  },
};

 . . .
export default function App() {
   . . .
}

Diese Methode kann für alle anderen Dropdown-Felder und zum Zurücksetzen der Seite verwendet werden.

export default function App() {
  . . .
    return (
    <View>



<p>handle focus / blur<br>
</p>

<pre class="brush:php;toolbar:false">var focusField = "";
export default function App() {
. . .

 const changeFocusField = (fld = "") => {
  focusField = fld;
  setRefreshPage(!refreshPage);
 };
. . .
}

Die Dropdown-Liste „Status“ ist jetzt perfekt geladen.

Laden Sie den Rest (Stadt, Dorf, Straße)

Wie zuvor laden wir Daten für die restlichen Felder.

<ZDropDown
. . .
  isFocus={focusField === ele}
  onFocus={() => {
    changeFocusField(ele);
  }}
  onBlur={() => changeFocusField("")}
  onChange={(item) => {}}
 />

Gut, alle Dropdowns sind mit der entsprechenden Liste gefüllt.

Cascading Form React Native Advanced

Validierung

Bevor wir die Dropdown-Liste anzeigen, müssen wir das übergeordnete Feld validieren. Wir werden also die übergeordneten Felder vom Formularfeldobjekt abrufen. Dann iterieren Sie sie einzeln, validieren Sie den Wert und zeigen Sie bei Bedarf eine Warnung an.

const listCountry = [
  { countryId: "1", name: "india" },
  { countryId: "2", name: "uk" },
  { countryId: "3", name: "canada" },
  { countryId: "4", name: "us" },
];

const listSate = [
  { stateId: "1", countryId: "1", name: "state1_india" },
  { stateId: "4", countryId: "2", name: "state1_uk" },
  { stateId: "7", countryId: "3", name: "state1_canada" },
  { stateId: "10", countryId: "4", name: "state1_us" },
];

const listCity = [
  { cityId: "1", stateId: "1", countryId: "1", name: "city1_state1_country1" },
  { cityId: "5", stateId: "2", countryId: "1", name: "city5_state2_country1" },
  {
    cityId: "21",stateId: "7",countryId: "3",name:"city21_state7_country3",
  },
  {
    cityId: "26",stateId: "9",countryId: "3",name: "city26_state9_country3",
  },
];

const listVillage = [
  { cityId: "1", villageId: "1", name: "village 1  city 1" },
  { cityId: "2", villageId: "5", name: "village 5  city 2" },
  { cityId: "3", villageId: "9", name: "village 9  city 3" },
  { cityId: "4", villageId: "10", name: "village 10  city 4" },
];

const listStreet = [
  { villageId: "1", streetId: "1", name: "village 1 street 1" },
  { villageId: "1", streetId: "109", name: "village 1 street 109" },
  { villageId: "2", streetId: "2", name: "village 2 street 2" },
  { villageId: "2", streetId: "110", name: "village 2 street 110" },
];
 . . .
export default function App() {
  . . .
}
 . . .

Cascading Form React Native Advanced

Formular zurücksetzen

Schließlich bieten wir die Möglichkeit, die Formularfelder zurückzusetzen.

export default function App() {
  . . .
  const allValuesSelected = () => {
    console.log("All fields value selected");
  };

  const loadStreet = async () => {};

  const loadVillage = async () => {};

  const loadCity = async () => {};

  const loadState = async () => {};

  const loadCountry = async () => {};

  const loadPageData = () => {
    formFields.country.onValueSelected = loadState;
    formFields.state.onValueSelected = loadCity;
    formFields.city.onValueSelected = loadVillage;
    formFields.village.onValueSelected = loadStreet;
    formFields.street.onValueSelected = allValuesSelected;    
  };

  return (. . .);
}

Alles erledigt. Jetzt haben wir gesehen, wie man mit dynamischen Formularfeldern umgeht, Felder rendert, Daten lädt und validiert.

Dies sind meine drei Ansätze zum Umgang mit kaskadierenden Formularfeldern.

Ich hoffe, dieser Beitrag/diese Serie enthält einige nützliche Dinge, die Ihnen gefallen. Danke schön.

Vollständiger Code hier

Das obige ist der detaillierte Inhalt vonKaskadierende Form React Native Advanced. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn