如何在React JS中使用fetch从REST API获取预测

我正在开发一个应用程序,其中Flask REST API接受两个字符串并返回一个浮点值作为预测。现在我正在尝试连接到React应用程序,以便可以在网页上显示这些预测。

目标:从前端获取两个字符串,使用REST API进行推理,并在前端显示预测值。

下面是用于在React应用程序中获取REST API预测的代码。

function App() {  const [state, setState] = useState([{}]);  useEffect(() => {    fetch("/predict?solute=CC(C)(C)Br&solvent=CC(C)(C)O")      .then((res) => res.json())      .then((data) => {        setState(data);        console.log(data);      });  }, []);

在fetch中的/predict?solute=CC(C)(C)Br&solvent=CC(C)(C)O这里,solute=CC(C)(C)Brsolvent=CC(C)(C)O是传递给Flask REST API用于生成预测的输入。

但我想从前端而不是在URL中指定这些输入。如何实现?

修改后的代码用于获取和显示结果

function App() {  const [state, setState] = useState([{}]);  const [uri, setUri] = useState([{}]);  const [resultstate, setResultState] = useState([{}]);  function HandleSubmit() {    const uri = "http://127.0.0.1:3000/?${form.one}&${form.two}";    setUri(uri);    useEffect(() => {      fetch(uri)        .then((response) => {          if (response.status === 200) {            return response.json();          }        })        .then((data) => {          setResultState(data);          console.log(data);        });    });  }  function handleChange(e) {    const { nodeName, name, value } = e.target;    if (nodeName === "INPUT") {      setState({ ...FormData, [name]: value });    }  }  return (    <div className="App">      <state onChange={handleChange}>        <fieldset>          <legend>Solute</legend>          <input name="one" value={state.one} />        </fieldset>        <fieldset>          <legend>Solvent</legend>          <input name="two" value={state.two} />        </fieldset>        <button type="button" onClick={HandleSubmit}>          Submit        </button>      </state>      <Deploy />    </div>  );}

运行修改后的代码时,我得到了这个错误enter image description here


回答:

  1. 创建一个新的form状态。

  2. 创建一个包含一些输入元素和一个提交表单按钮的表单。

  3. 当输入元素的值发生变化时,使用它们的数值更新form状态。

  4. 当表单提交时,使用form中的信息创建一个新的URI,然后执行fetch操作。

const { useState } = React;function Example() {  const [ form, setForm ] = useState({});  function handleSubmit() {    const uri = `http://example.com/?${form.one}&${form.two}`;    console.log(`Current state: ${JSON.stringify(form)}`);    console.log(`Fetch URI: ${uri}`);    // fetch(uri)... etc  }  // 由于监听器附加在表单元素上  // (见下面的“附加文档”)  // 检查被更改的元素是否为输入  // 然后使用名称作为键更新状态对象,  // 并将输入的值作为该键的对象值添加  function handleChange(e) {    const { nodeName, name, value } = e.target;    if (nodeName === 'INPUT') {      setForm({ ...form, [name]: value });    }  }  // 每个输入都有一个名称,并从表单状态中维护其  // 值  return (    <form onChange={handleChange}>      <fieldset>        <legend>Input one</legend>        <input name="one" value={form.one} />      </fieldset>      <fieldset>        <legend>Input two</legend>        <input name="two" value={form.two} />      </fieldset>      <button type="button" onClick={handleSubmit}>Submit</button>    </form>  );};ReactDOM.render(  <Example />,  document.getElementById('react'));
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/17.0.2/umd/react.production.min.js"></script><script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/17.0.2/umd/react-dom.production.min.js"></script><div id="react"></div>

附加文档

  • 事件委托 – 这就是我们将一个监听器附加到表单上而不是所有输入上的原因。表单捕获从输入冒泡到DOM的事件。但这也是为什么我们需要识别它们是什么元素的原因,因此需要nodeName

  • 解构赋值

Related Posts

使用LSTM在Python中预测未来值

这段代码可以预测指定股票的当前日期之前的值,但不能预测…

如何在gensim的word2vec模型中查找双词组的相似性

我有一个word2vec模型,假设我使用的是googl…

dask_xgboost.predict 可以工作但无法显示 – 数据必须是一维的

我试图使用 XGBoost 创建模型。 看起来我成功地…

ML Tuning – Cross Validation in Spark

我在https://spark.apache.org/…

如何分析ML.NET中多类分类预测得分数组?

我在ML.NET中创建了一个多类分类项目。该项目可以对…

### 卷积神经网络 – 1D – 特征分类错误

我正在尝试修改下面的示例,以模拟我的数据集的CNN,并…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注