使用机器学习数据集构建销售预测Web应用程序( 四 )
- bootstrap文档:
...............
我们的最终用户界面是集合下拉菜单项 , 其中单个项如下所示:文章插图
我们将在src文件夹中创建一个名称为optionsSources.json的JSON文件 。 JSON文件中的每个条目都包含以下对象:
{"CONSOLE": {"options": ["ps2","x360","ps3","pc"],"icon": "?","dropDownPlaceholder": "Select Console"}}
下拉菜单中显示的选项位于options数组中 , 下拉菜单选项左侧显示的图标和标签位于icon和dropDownPlaceholder项 。 我们需要创建多个这样的下拉列表 , 因此要添加的完整JSON文件如以下文件所示:我们将编写一个功能组件 , 该组件返回一个下拉项 , 如下所示:
import React,{ useState } from 'react';import optionSources from'../optionsSources.json';function OptionSelection({itemKey, setOptionInObject}) {const title = optionSources[itemKey].dropDownPlaceholder;const icon = optionSources[itemKey].icon;return({icon}{` ${title}`}{title}{renderOptionsDropdown()})}export default OptionSelection;
在上面的组件中 , 我们itemKey从第3行的父组件中获得prop(param)值 。 我们假设itemKey从父组件接收的是CONSOLE 。 在第4行和第5行 , 我们首先提取显示在下拉菜单左侧的标题和图标 。 然后 , 根据Boostrap文档在创建下拉列表时 , 在第6行的返回函数中使用HTML标签 。接下来 , 我们需要实现renderOptionsDrop在返回函数中定义的函数 , 如下所示:
import optionSources from'../optionsSources.json';function OptionSelection({itemKey, setOptionInObject}) {...const renderOptionsDropdown = () => {const selectionOptions = optionSources[itemKey].options;return selectionOptions.map((selectionOption, index)=>{return (handleDropDownSelection(selectionOption)}>{selectionOption});})}...}
在第5行 , 我们从optionSources JSON对象获取特定项的options数组 , 并将其存储在selectionOptions变量中 。然后在第6行 , 我们使用map函数迭代数组并显示下拉选择项 。 我们必须在第10行使用onClick函数更新下拉项的选定值 。
然后实现onClick处理程序中的函数handleDropDownSelection , 如下所示:
import React,{ useState } from 'react';...function OptionSelection({itemKey, setOptionInObject}) {const [currentSelectedOption, setSelectedOption] = useState(null);const handleDropDownSelection = (consoleOption) => {setSelectedOption(consoleOption)setOptionInObject(itemKey, consoleOption)}...}
我们在第1行输入了useState hook 。 它是一个内部函数 , 允许我们使用状态变量的概念动态更新值 。 关于这个函数的更多信息可以在这里找到:- React useState docs:
这个组件的完整代码可以在这里找到:
然后我们在src文件夹中导入此选项并对服务器进行API调用 。 完整的代码可以在这里找到:
import React, {useState} from 'react';import axios from 'axios';function App() {...const handleInputSubmission = () => {if(selectedObject} else {setRequestFailed("Please select all fields before submitting request")}}}
我们正在使用Axios npm模块对后端Heroku服务器进行POST API调用 。 确保在process.env.REACT_APP_HEROKU_SERVER_URL占位符的第8行上添加自己的Heroku服务器URL , 以接收来自服务器API的响应 。最好将API URL变量保存在.env文件中 , 然后在部署环境中进行设置 。 可以在这里找到更多详细信息:
- Env变量:
- 视频游戏销售预测前端:
第5部分:将客户端应用程序部署到NetlifyNetlify是一个可以轻松在线部署静态网站的平台 。 在部署使用createreact app模块生成的应用程序时 , 它有一个非常简单的过程 。 我们将利用此服务在线托管我们的web应用程序 。
首先 , 我们需要在Github上创建一个帐户 。
- 会员|美容院使用会员管理软件给顾客更好的消费体验!
- 桌面|日常使用的软件及网站分享 篇一:几个动态壁纸软件和静态壁纸网站:助你美化你的桌面
- QuestMobile|QuestMobile:百度智能小程序月人均使用个数达9.6个
- 机器人|网络里面的假消息忽悠了非常多的小喷子和小机器人
- 跑腿|机器人“小北”上岗 让办事群众少跑腿
- 计算机学科|机器视觉系统是什么
- 轻松|使用 GIMP 轻松地设置图片透明度
- 机器人|外骨骼康复训练机器人助力下肢运动功能障碍患者康复训练
- 电池容量|Windows 自带功能查看笔记本电脑电池使用情况,你的容量还好吗?
- 教学|机器人教学的目标方案