简体   繁体   English

从另一个对象数组[配置]中的对象数组[表单]访问JSON数据检查下面的Json数据

[英]Accessing JSON data from array of objects [form] who is inside another array of objects [configuration] check the Json Data below

Hello World!你好世界!

I want to render data into my contact form screen (I want the screen to be 100% configurable using call api)我想将数据呈现到我的联系表单屏幕中(我希望屏幕可以 100% 使用调用 api 进行配置)

Fisrt I want to render the title[Contact Us] and the subtitle[Enter your details to contact us] from the configuration Array [Done]首先我想从配置数组[Done]中渲染标题[Contact Us]和副标题[Enter your details to contact us]

Second I want to render the objects on the Form Array into an inputs [Not Yet]其次,我想将 Form Array 上的对象渲染为输入[Not Yet]

Notice: I'm Getting No Error注意:我没有错误

this is the Code:这是代码:

import React, { useState,useEffect } from 'react';
import {
  View,
  Text,
  TextInput,
  SafeAreaView,
  Keyboard,
  ScrollView,
  Alert,
} from 'react-native';

import COLORS from '../src/conts/colors';
import Button from '../src/views/components/Button';
import Input from '../src/views/components/Input';
import Loader from '../src/views/components/Loader';

const ContactForm = ({navigation}) => {
  const [inputs, setInputs] = React.useState({
    firstname: '',
    lastname: '',
    email: '',
    note: '',
  });
  const [errors, setErrors] = React.useState({});
  const [loading, setLoading] = React.useState(false);

  const validate = () => {
    Keyboard.dismiss();
    let isValid = true;

    if (!inputs.firstname) {
      handleError('Please input first name', 'firstname');
      isValid = false;
    }

    if (!inputs.lastname) {
      handleError('Please input last name', 'lastname');
      isValid = false;
    }

    if (!inputs.email) {
      handleError('Please input email', 'email');
      isValid = false;
    } else if (!inputs.email.match(/\S+@\S+\.\S+/)) {
      handleError('Please input a valid email', 'email');
      isValid = false;
    }
    if (!inputs.note) {
      handleError('Please input note', 'note');
      isValid = false;
    }

    if (isValid) {
      submitData();
    }
  };
  const submitData = ()=>{
          fetch("https://flow.simpas.ai:2021/react/contact",{
              method:"post",
              headers:{
                'Content-Type': 'application/json'
              },
              body: JSON.stringify({
                  firstname: inputs.firstname,
                  lastname: inputs.lastname,
                  email: inputs.email,
                  note: inputs.note,
      })
          })
          .then(res=>res.json())
          .then(data=>{
              alert(`${data.firstname} is saved successfuly`);
              navigation.navigate("Home")
          })
          .catch(err=>{
            alert("someting went wrong")
        })

    };



  const handleOnchange = (text, input) => {
    setInputs(prevState => ({...prevState, [input]: text}));
  };
  const handleError = (error, input) => {
    setErrors(prevState => ({...prevState, [input]: error}));
  };
  const [data, getData] = useState([])
  const URL = "https://flow.simpas.ai:2021/react/contact";

  useEffect(() => {
      fetchData()
  }, [])


  const fetchData = () => {
      fetch(URL)
          .then((res) =>
              res.json())

          .then((response) => {
              console.log(response);
              getData(response);
          })
  }

  return (
    <SafeAreaView style={{ flex: 1}}>
      <Loader visible={loading} />
      <ScrollView
        contentContainerStyle={{paddingTop: 50, paddingHorizontal: 20}}>
        <Text style={{color: COLORS.black, fontSize: 40, fontWeight: 'bold',fontFamily: 'Roboto',textAlign: 'center'}}>
          {data?.title}
        </Text>
        <Text style={{color: COLORS.grey, fontSize: 18, marginVertical: 10,fontFamily: 'Roboto',textAlign: 'center'}}>
          {data?.subtitle}
        </Text>
        <View style={{ marginVertical: 20 }}>
      {data.data?.configuration[0]?.form?.map((item) => {
        return (
          <Input
            onChangeText={(text) =>
              handleOnchange(text, data?.configuration[0]?.form?.fieldname)
            }
            onFocus={() =>
              handleError(null, data?.configuration[0]?.form?.fieldname)
            }
            iconName="account-outline"
            label={data?.configuration[0]?.form?.title}
            placeholder={data?.configuration[0]?.form?.placeholder}
          />
        );
      })}

      <Button title="Contact Us" onPress={validate} />
</View>
      </ScrollView>
    </SafeAreaView>
  );
};

export default ContactForm;

This is The Json Data:这是 Json 数据:

{
   "title":"Contact us",
   "subtitle":"Enter your details to contact us",
   "action":"form",
   "configuration":[
      {
         "title":"Contact us",
         "subtitle":"Enter your details to contact us",
         "type":"action",
         "actiontype":"form",
         "posturl":"https://flow.simpas.ai/interview/content/123456/businesscard/",
         "form":[
            {
               "fieldtype":"field",
               "title":"First Name",
               "fieldname":"firstname",
               "placeholder":"Enter your first name",
               "iconurl":"https://www.creativefabrica.com/wp-content/uploads/2019/02/People-Icon-by-Kanggraphic-1-580x386.jpg",
               "fieldvalue":"",
               "required":true
            },
            {
               "fieldtype":"field",
               "title":"Last Name",
               "fieldname":"latstname",
               "placeholder":"Enter your last name",
               "iconurl":"https://www.creativefabrica.com/wp-content/uploads/2019/02/People-Icon-by-Kanggraphic-1-580x386.jpg",
               "fieldvalue":"",
               "required":true
            },
            {
               "fieldtype":"email",
               "title":"Email",
               "fieldname":"email",
               "placeholder":"Enter your email",
               "iconurl":"",
               "fieldvalue":"",
               "required":true
            },
            {
               "fieldtype":"textarea",
               "title":"Note",
               "fieldname":"note",
               "placeholder":"Enter your note",
               "iconurl":"",
               "fieldvalue":"",
               "required":true
            }
         ]
      }
   ]
}

The output should look like this:输出应如下所示:

在此处输入图像描述

But this is what Am Getting:但这就是我得到的:

在此处输入图像描述

try to change your code in this way尝试以这种方式更改您的代码

const formData = (data.?configuration[0] || {form:[]}).form
return (
    <SafeAreaView style={{ flex: 1}}>
      <Loader visible={loading} />
      <ScrollView
        contentContainerStyle={{paddingTop: 50, paddingHorizontal: 20}}>
        <Text style={{color: COLORS.black, fontSize: 40, fontWeight: 'bold',fontFamily: 'Roboto',textAlign: 'center'}}>
          {data?.title}
        </Text>
        <Text style={{color: COLORS.grey, fontSize: 18, marginVertical: 10,fontFamily: 'Roboto',textAlign: 'center'}}>
          {data?.subtitle}
        </Text>
        <View style={{ marginVertical: 20 }}>
      {formData.map((item) => {
        return (
          <Input
            onChangeText={(text) =>
              handleOnchange(text, item.fieldname)
            }
            onFocus={() =>
              handleError(null, item.fieldname)
            }
            iconName="account-outline"
            label={item.title}
            placeholder={item.placeholder}
          />
        );
      })}

      <Button title="Contact Us" onPress={validate} />
</View>
      </ScrollView>
    </SafeAreaView>
  );

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM