使用 React 构建 BMI 计算器

使用 react 构建 bmi 计算器

使用 react 构建 bmi 计算器

介绍

体重指数(bmi)是一种广泛使用的指标,用于确定一个人在给定身高下是否拥有健康体重。在本博客中,我们将逐步介绍如何使用 react 创建一个简单但实​​用的 bmi 计算器。这个项目允许用户输入他们的体重和身高来计算他们的bmi,并根据结果提供分类。

项目概况

bmi 计算器是一个使用 react 构建的响应式 web 应用程序。它将用户的体重(以千克为单位)和身高(以厘米为单位)作为输入并计算 bmi。然后,应用程序会显示计算出的 bmi 以及相应的体重分类,例如体重不足、正常体重、超重或肥胖。

特征

用户友好的界面:简单干净的用户界面,易于导航。实时计算:用户可以通过输入体重和身高立即计算出自己的bmi。响应式设计:计算器响应灵敏,在不同的屏幕尺寸上运行良好。体重分类:根据计算出的bmi,告知用户自己的体重状况。

使用的技术

react: 用于构建用户界面的核心库。javascript: 用于处理 bmi 计算的逻辑。css: 设置应用程序样式并确保响应式设计。

项目结构

以下是该项目结构的简要概述:

src/│├── assets/│   └── images/│       └── bmi logo.png├── components/│   └── bmicalculator.jsx├── app.jsx├── app.css└── index.css

登录后复制

代码说明

1.bmi计算器组件

该组件是应用程序的核心。它处理用户输入、执行 bmi 计算并显示结果。

import { usestate } from "react";import logoimg from "../assets/images/bmi logo.png";const bmicalculator = () => {  const [weight, setweight] = usestate("");  const [height, setheight] = usestate("");  const [bmi, setbmi] = usestate("");  const [result, setresult] = usestate("");  function calculatebmi(weight, height) {    const heightm = height / 100;    const bmiresult = weight / (heightm * heightm);    setbmi(bmiresult.tofixed(2)); // round to 2 decimal places    if (bmiresult < 18.5) {      setresult("underweight");    } else if (bmiresult < 24.9) {      setresult("normal weight");    } else if (bmiresult  {    if (weight && height) {      calculatebmi(weight, height);    }  };  return (    
@@##@@

weight (kg)

setweight(e.target.value)} />

height (cm)

setheight(e.target.value)} />

your bmi : {bmi}

result : {result}

);};export default bmicalculator;

登录后复制

2. 应用程序组件

app 组件作为主容器,包装 bmicalculator 组件并添加页眉和页脚。

import bmicalculator from "./components/bmicalculator";import "./app.css";const app = () => {  return (    

bmi calculator

made with ❤️ by abhishek gurjar

);};export default app;

登录后复制

3. 设置应用程序样式 (app.css)

css 确保应用程序具有视觉吸引力和响应能力。

* {  box-sizing: border-box;}body {  margin: 0;  padding: 0;  font-family: sans-serif;  background-color: #008f7d;  color: white;}.app {  display: flex;  flex-direction: column;  align-items: center;  justify-content: space-between;  margin-top: 30px;}.header {  text-align: center;  font-size: 18px;}.bmi-container {  margin: 40px;  width: 500px;  height: 430px;  background-color: white;  color: black;  border-radius: 15px;  display: flex;  flex-direction: column;  align-items: center;  justify-content: center;  box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;}.logo img {  width: 50px;  height: 50px;  margin: 15px;}.input-box {  display: flex;  flex-direction: column;  align-items: center;}.input-box h4 {  color: gray;}.weight-input,.height-input {  display: flex;  align-items: center;  justify-content: space-between;  gap: 25px;}.weight-input input,.height-input input {  height: 27px;  width: 180px;  font-weight: 400;  font-size: 14px;  border-radius: 7px;}.btn {  margin: 15px;  width: 65%;  height: 10%;  display: flex;  align-items: center;  justify-content: center;  background-color: #087fff;  color: white;  border: 0.5px solid black;  border-radius: 7px;}.btn:hover {  background-color: #2570c1;}.output-box {  margin-top: 20px;  width: 65%;  height: 15%;  display: flex;  flex-direction: column;  align-items: flex-start;  justify-content: center;  background-color: #e2e2e2;  color: black;  border-radius: 7px;  border: 1px solid black;}.output-box p {  margin-left: 20px;  line-height: 0;}.footer {  text-align: center;  font-size: 14px;}

登录后复制

安装与使用

要在本地计算机上运行 bmi 计算器,请按照以下步骤操作:

克隆存储库:

   git clone https://github.com/abhishekgurjar-in/bmi-calculator-react.git

登录后复制安装依赖项:导航到项目目录并运行:

   npm install

登录后复制启动应用程序:通过运行以下命令启动应用程序:

   npm start

登录后复制

应用程序应在默认 web 浏览器中打开,地址为 http://localhost:3000。

现场演示

在此处查看 bmi 计算器的现场演示。

结论

在这个项目中,我们使用 react 构建了一个简单而有效的 bmi 计算器。该项目演示了如何使用 react 状态管理、条件渲染和基本样式来创建用户友好的界面。无论您是刚刚开始使用 react 还是想练习自己的技能,这个项目都是获得实践经验的好方法。

制作人员

标志:本项目使用的bmi标志来自unsplash。灵感:该项目的灵感来自于在线提供的各种 bmi 计算器。

作者

abhishek gurjar 是一位充满热情的 web 开发人员,专注于构建直观且响应灵敏的 web 应用程序。跟随他的旅程并在 github 上探索更多项目。

bmi logo

以上就是使用 React 构建 BMI 计算器的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2854017.html

(0)
上一篇 2025年3月10日 14:45:22
下一篇 2025年2月22日 13:30:06

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • CSS 中的版式和字体样式

    讲座 4:css 中的版式和字体样式 在本次讲座中,我们将探讨如何使用 css 设置文本样式。版式是网页设计的一个重要方面,影响可读性、用户体验和整体美观。在本讲座结束时,您将了解如何在网站上应用各种字体样式并控制文本外观。 了解网页字体 …

    2025年3月10日
    200
  • 使用 API 和 JSON 的 Shopify Liquid REPL

    我非常兴奋 ? 分享我的新网站 Shopify Liquid REPL。 我最近看到 Taylor Page 关于 Shopify REPL (Read-Eval-Print-Loop) 的帖子,这促使我查看了该网站。检查网站的输出后,我创…

    2025年3月10日
    200
  • 使用 Tailwind CSS 创建流星边框动画

    在这篇博文中,我们将使用 tailwind css 创建一个迷人的“流星”边框动画。此效果为输入字段提供发光的动画边框,可以吸引用户的注意力 – 非常适合电子邮件注册或重要通知等号召性用语部分。 演示 在深入研究代码之前,您可以…

    2025年3月10日
    200
  • HTML、CSS 和 JavaScript 项目

    欢迎来到我的 html、css 和 javascript 项目集合!这篇博文全面概述了我创建的各种项目,展示了 web 开发的不同方面。每个项目都可以在自己的存储库中找到,其中包含您需要探索和学习的所有代码。 目录 简介项目概况开始使用贡献…

    2025年3月10日
    200
  • Riva – Tailwind CSS 仪表板模板生成器

    大家好! 我想向您介绍 Riva Dashboard,这是一个用于 Tailwind CSS 的拖放式仪表板模板生成器,旨在帮助开发人员加快开发过程。 Riva 构建于 Tailwind CSS 之上,具有以下功能,包含 72 多个组件(更…

    2025年3月10日
    200
  • 介绍我的新 Bootstrap olor 调色板生成工具

    嘿,开发者社区! ? 我很高兴分享我一直在开发的一个新工具,它将使您的网页设计过程更加顺畅和更加个性化。如果您发现自己想要更多地控制网站的配色方案,那么这个工具适合您! ? 它有什么作用? 这个 Bootstrap 5 调色板生成器工具可让…

    2025年3月10日
    200
  • 带有媒体查询的响应式网页设计

    第 6 讲:带有媒体查询的响应式网页设计 在本次讲座中,我们将深入探讨响应式网页设计,这是创建在从台式机到智能手机的所有设备上看起来都很棒的网站的关键技能。响应式设计的关键是使用媒体查询,它允许您根据屏幕尺寸或设备特性应用不同的样式。 了解…

    2025年3月10日
    200
  • 如何将 CSS 样式添加到 HTML 页面:初学者指南

    简介想象一下您在厨房里,准备准备一道菜。主要成分 (html) 摆在您面前:肉、蔬菜、香料。但要将这些食材转化为烹饪杰作,您需要烹饪技术、调味料和摆盘——这就是 css(层叠样式表)发挥作用的地方。 css 就像网络的“调味艺术”:没有它,…

    2025年3月10日
    200
  • How to create typography tokens for a design system using Sass mixins

    许多设计系统都是从颜色和尺寸等基本设计标记开始的,这些标记可以轻松转换为 css 变量(或 sass 或 less 等)。 // tokens.scss$primary-text-color: #aaa;$secondary-text-co…

    2025年3月10日
    200
  • 仅使用 CSS 从图像中删除背景

    注意:我刚刚翻译了下面的文字并将其发布在这里。参考文献位于本文末尾。 在这篇适合初学者的博客文章中,我们将学习如何仅使用 css(特别是 css 属性 mix-blend-mode)从图像中删除背景。此技术可用于创建有趣的视觉效果并通过减少…

    2025年3月10日
    200

发表回复

登录后才能评论