欢迎光临

我们一直在努力
当前位置:首页 > 编程技术 >

使用React组件编写温度显示器

日期:
后台-插件-广告管理-首页/栏目/内容广告位一(PC)
后台-插件-广告管理-首页/栏目/内容广告位一(手机)

本文实例为大家分享了React组件编写温度显示器的具体代码,供大家参考,具体内容如下

这是模拟了一下温度显示器的效果,先看效果:

先在页面中引入React等;

import React from "react";
import ReactDOM from "react-dom";
import "./index.css"; // 页面的样式文件

开发过程是这样的:

首先定义一个BoillingVerdict组件,用来显javascript示温度显示器的(样式先不写,在后面一起上代码)(温度显示器上的数字不是温度;),

// 显示温度计算器文字的函数组件(最高300摄氏度)
function BoillingVerdict(props) {
 return (
  <div className="outer">
   <div className="inner">

然后,创建一个名为 Calculator 的组件,用于渲染  '控制温度的输入框' 和 温度显示器组件,

class Calculator extends React.Component {
 // 构造函数,可以用于初始化state
 constructor(props) {
  super(props);
  this.state = {
   temperature: 0, // 温度
   tempHeight: 0, // 温度显示器背景色高度
   bg: "#fff", // 温度显示器颜色
  };
  // 为tempChange方法绑定this,否则该方法中拿不到this
  this.tempChange = this.tempChange.bind(this);
 }
 tempChange(e) {
 // 判断温度值大小来设置颜色
  var colors =
   Number(e.target.value) > 90 ? "#0F1CED" : Number(e.target.value) > 80 ? "#D5D70B" :
   Number(e.target.value) > 70 ? "#0BD737" : Number(e.target.value) > 60 ? "#0BD7CA" :
   Number(e.target.value) > 50 ? "#ED194B" : Number(e.target.value) > 40 ? "#AE1FD2" :
   Number(e.target.value) > 30 ? "skyblue" : Number(e.target.value) > 20 ? "blue" :
   Number(e.target.value) > 10 ? "orange" : "#671552";
  var height = (Number(e.target.value) / 3).toFixed(2);
  this.setState({
   temperature: e.target.value,
   tempHeight: height,
   bg: colors,
  });
 }
 render() {
  return (
   <fieldset>
    <legend> 温度: </legend>
    <input valueZzDfWMYUGa={this.state.temperature} > </input>
    <BoillingVerdict height={this.state.tempHeight} bg={this.state.bg}></BoillingVerdict>
   </fieldset>
  );
 }
}

然后渲染:

ReactDOM.render(<Calculator></Calculator>,document.getElementById("root12"));

index.css

.outer{
 width:80px;
 height:300px;
 border:1px solidjs black;
 border-radius: 20px;
 overflow: hidden;
 background:#fff;
 margin-top:10px;
 position:relative;
 text-align: center;
}
.inner{
 position:absolute;
 bottom:0;编程height:200px;
 background:#fff;
 width:100%;
 background:blue;
 text-align: center;
 transition: all 1s;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

后台-插件-广告管理-首页/栏目/内容广告位二(PC)
后台-插件-广告管理-首页/栏目/内容广告位二(手机)
后台-插件-广告管理-内容广告位三(PC)
后台-插件-广告管理-内容广告位三(手机)

相关阅读

  • react-dnd实现任意拖动与互换位置

  • 本文实例为大家分享了react-dnd实现任意拖动与互换位置的具体代码,供大家参考,具体内容如下
    react-dnd用法
    hooks组件
    1.使用DndProvider定义一个可以拖拽的范围
    import { htm
  • react优雅处理多条件鼠标拖拽位移

  • 本文实例为大家分享了react优雅处理多条件鼠标拖拽位移的具体代码,供大家参考,具体内容如下

    场景
    三种拖拽条件 可纵轴 横轴 和全部方向 如果加3个监听重复代码太多
    因为状态
  • React日期时间显示组件的封装方法

  • 本文实例为大家分享了React日期时间显示组件的封装具体代码,供大家参考,具体内容如下
    时间日期展示器

    import ProtoType from 'prop-types';
    import { useState, useEffect }
  • react实现拖拽模态框

  • 前言
    实际开发中,模态框展现数据会经常出现.但不幸的是有时功能开发完了,UI同学突然提出需求希望模态框能拖拽.本文使用的模态框由 ant design 3.0 的 Modal 组件封装而成,
  • react-three-fiber实现炫酷3D粒子效果首页

  • 目录背景Three.js工作原理场景(Scene)相机(Camera)渲染器(renderer)网格对象(mesh)react-three-fiber画布(Canvas)3D粒子模型构建实现思路定义buffer几何体,并填充数据将buff
  • 最新版React Native环境搭建(亲测)

  • 目录一、基础环境1.1 安装Node.js1.2 添加android原生环境1.3 添加IOS原生环境二、创建示例项目2.1 创建项目2.2 运行项目2.3 调试项目三、集成到原生应用3.1 集成到原生And
  • React拖拽调整大小的组件

  • 本文实例为大家分享了React拖拽调整大小的组件,供大家参考,具体内容如下
    一、实现流程
    1.使用React.cloneElement加强包裹组件,在包裹的组件设置绝对定位,并在组件内加上四个可
  • react实现自定义拖拽hook

  • 前沿
    最近发现公司的产品好几个模块用到了拖拽功能,之前拖拽组件是通过html5 drag Api 实现的但体验并不是很好,顺便将原来的拖拽组建稍做修改,写一个自定义hook,方便大家使用
  • react实现消息显示器

  • 本文实例为大家分享了react实现消息显示器的具体代码,供大家参考,具体内容如下
    效果


    代码实现
    完整代码:
    import React from 'react';
    import styles from './styles.less';
  • React实现pc端的弹出框效果

  • 本文实例为大家分享了React实现pc端弹出框效果的具体代码,供大家参考,具体内容如下
    最近学习react碰见了一个小坑 不知道为什么 我在做一个弹出框的小demo

    很简单的一个小dem
后台-插件-广告管理-内容广告位四(PC)
后台-插件-广告管理-内容广告位四(手机)

热门文章

后台-插件-广告管理-侧边广告位一(PC)
后台-插件-广告管理-侧边广告位一(手机)
  • HTML 表单组件实例代码

  • HTML 表单用于搜集不同类型的用户输入。下文通过代码给大家分享html 表单组件实例代码,感兴趣的朋友参考下吧 废话不多说了,直接给大家贴代码了,具体代码如下所示: <!DOCTYPE
  • html2canvas 将html代码转为图片的使用方法

  • 转换代码到图片使用 html2canvas,这是一个非常著名的从浏览器网页截图的开源库,使用很方便,功能也很强大。 使用 html2canvas http:// html2canvas 的使用非常简单,简单
  • HTML网页中插入视频的方法小结

  • 现在如果要在页面中使用video标签,需要考虑三种情况,支持Ogg Theora或者VP8(如果这玩意儿没出事的话)的(Opera、Mozilla、Chrome),支持H.264的(Safari、IE 9、Chrome),都不支持的(IE6、
  • HTML实现文本框只读不能修改其中的内容

  • 废话不多说了,直接给大家贴代码了,具体代码如下所示: <!--方法1:>http:// 当鼠标放不上就离开焦点 --> <input type="text" name="input1" value=http://www.cppcns.com/web
  • 移动端专用的meta标签设置大全

  • 前言 之前学习前端中,对meta标签的了解仅仅只是这一句。 <meta charset="UTF-8"> 但是打开任意的网站,其head标签内都有一列的meta标签。比如我们我们网站,但是自己却很不熟
后台-插件-广告管理-侧边广告位二(PC)
后台-插件-广告管理-侧边广告位二(手机)

最新文章

  • 在Asp.net core项目中使用WebSocket

  • 今天小试了一下在ASP.NET core中使用websocket,这里记录一下: 在 Startup 类的 Configure 方法中添加 WebSocket 中间件。 app.UseWebSockets(); 它也可以传入一些参数 app.Us
  • Vue快速理解事件绑定是什么

  • 目录一、监听事件二、事件修饰符1、stop修饰符阻止事件冒泡2、capture修饰符3、self修饰符4、prevent修饰符5、键盘事件修饰符6、鼠标事件修饰符一、监听事件 监听事件一般
  • C#实现模拟ATM自动取款机功能

  • 目录(1)关于用户帐号的类:Account(2)关于银行数据库的类:BankDatabase(3)关于ATM屏幕显示的类:Screen(4)关于ATM键盘的类:Keypad(5)关于进钞、出钞口的类:DepositSlot(6)关于ATM
  • Java设计模式之抽象工厂模式浅析讲解

  • 1.介绍 当系统准备为用户提供一系列相关对象,又不想让用户代码和这些对象形成耦合时,就可以使用抽象工厂模式。 2.如何实现 1)抽象产品--Car 2)具体产品--BYDCar、TSLCar 3)抽象
  • 如何动态替换Spring容器中的Bean

  • 目录动态替换Spring容器中的Bean原因方案实现Spring中的bean替换问题动态替换Spring容器中的Bean 原因 最近在编写单测时,发现使用 Mock 工具预定义 Service 中方法的行为特
  • C#优雅的实现INotifyPropertyChanged接口

  • INotifyPropertyChanged接口在wpF或WinFrom程序中使用还是经常用到,常用于通知界面属性变更。标准写法如下: class NotifandroidyObject : INotifyPropertyChanged {
后台-插件-广告管理-侧边广告位三(PC)
后台-插件-广告管理-侧边广告位三(手机)