React简单教程-4-事件和hook
前言
在上一章 React 简单教程-3-样式 中我们建立了一个子组件,并稍微美化了一下。在另一篇文章 React 简单教程-3.1-样式之使用 tailwindcss 章我们使用了 tailwind 来写样式,以后我代码里的样式都会使用 tailwind 来写。
这一章,我将给我们的子组件加一个按钮,以实现交互的功能。
什么功能?
我们现在的子组件如下图:

现在它没有交互功能,我想给他的灰色按钮加一个点击事件,点击后将内容收起,如下:

实现
首先,我们的灰色按钮,现在只是一个 span 元素,需要先将它换成 button 元素,样式不变,我们只需要直接将标签从 span 换成 button 就可以了。
export function Displayer(props: { name: string, content: string }) {
  const name = props.name;
  const content = props.content;
  return (
    <div className="bg-gray-800 text-white p-2 m-2 rounded-lg">
      <div className="nav">
        <span className="btn-red"></span>
        <span className="btn-yellow"></span>
        {/* 灰色按钮 */}
        <button className="btn-gray"></button>
      </div>
      <div className="body">
        <div>{name}</div>
        <div>{content}</div>
      </div>
    </div>
  );
}
之后添加点击事件。就跟我们在 html 元素上添加一样,在按钮的 onclick 里绑定事件,React 也一样,但是写法需要是小驼峰写法:onClick,React 的组件所有属性都是小驼峰下发。我们在组件里定义一个方法用来处理这个按钮的事件,然后将方法赋给 onClick 属性:
export function Displayer(props: { name: string, content: string }) {
  //    忽略
  //    定义的处理方法
  function handleClick() {}
  return (
    <div className="bg-gray-800 text-white p-2 m-2 rounded-lg">
      {/* 忽略 */}
      {/* 灰色按钮 */}
      <button className="btn-gray" onClick={handleClick}></button>
      {/* 忽略 */}
    </div>
  );
}
我们绑定方法的时候,方法名要写在花括号里,根据规范,处理事件的方法一般以 handle 开头。现在我们的方法 handleClick 里没有任何实现。
接下来,要隐藏我们的内容元素,可以直接使用 hidden 属性来隐藏:
<div className="body" hidden></div>
但是这是静态的操作,我们要在点击按钮后动态隐藏。我们会想到定义一个变量 isHidden,将变量赋给要隐藏的元素:
<div className="body" hidden="{isHidden}"></div>
通过按钮事件,将值变为 true,当值为 true 时,元素就隐藏了。但是如果你试一遍的话,就会发现是不起效的。因为你只是改变了变量,没有重绘界面,所以界面是不会变化的。
在 React 里需要怎么做呢?
使用 useState hook
什么是 hook?在本文中,我不打算详细介绍什么是 hook(下一章里我会介绍),但是我想先让你感受下 hook。在 react 中,你会经常看到以 use 开头的方法,你可以认为这些方法就是 hook,是 React 提供的用于实现一些特性的功能。这里我们将使用这个 hook 来解决上面的问题。
hook useState 是干什么的?跟随下面一边写一边感受一下。
导入 useState 并使用:
//  导入 hook
import { useState } from "react";
export function Displayer(props: { name: string, content: string }) {
  //  使用 hook
  const [hidden, setHidden] = useState(false);
}
看示例,hook 就是一个方法,也跟使用方法一样使用。在示例中,useState(false) 返回了一个数组,数组中的第一个参数是一个变量,第二个参数是修改这个变量的方法,使用 useState 可以传入这个变量的默认值,在示例中,我传入了 false,根据类型推断,数组中的第一个参数被推断出是 boolean 类型。
从这里,你应该能够看出,hook useState 的作用是创建变量。和一般变量的不同的地方在于,它提供了修改这个变量的方法 setHidden,这个修改的方法,特点在于,它会重绘这个组件!
也就是说,当我们调用 setHidden,传入新的值,修改了变量后,它会让这个组件的界面更新一遍,这样,组件的界面就可以发生变化了!
在我们的子组件中感受一下,使用 useState 创建的变量来代替我们的 isHidden 变量,代码如下:
export function Displayer(props: { name: string, content: string }) {
  //    忽略
  const [hidden, setHidden] = useState(false);
  function handleClick() {
    setHidden(true);
  }
  return (
    <div className="bg-gray-800 text-white p-2 m-2 rounded-lg">
      <div className="nav">
        {/* 忽略 */}
        <button className="btn-gray" onClick={handleClick}></button>
      </div>
      <div className="body" hidden={hidden}>
        {/* 忽略 */}
      </div>
    </div>
  );
}
在上面的代码上,按钮 button 的 onClick 绑定了处理函数,函数里调用了 setHidden(true);,将 hidden 的值设为 true,并触发了重绘,重绘时,因为 hidden 的值为 true,内容元素的 hidden 被触发,内容元素隐藏。

就这样,实现了我们点击隐藏的效果。亲手试一试,感受一下 hook。
扩展习题
你能不能扩展这个功能,让按钮再点击一下,就展开内容元素?
总结
- 本文章我们学会了按钮元素点击事件的用法。其他事件的用法也大同小异,比如 onChang。
- 学会了第一个 hook:useState,并知道这个 hook 起到了什么作用。
在下一章中,将介绍其他几个常用 hook。
React简单教程-4-事件和hook的更多相关文章
- React简单教程-6-单元测试
		前言 我想大部分人的前端测试,都是运行项目,直接在浏览器上操作,看看功能正不正常.虽然明明有测试库可以使用,但是因为"要快"的原因,让好好做测试变成了一件影响效率的事. 因为这种无 ... 
- React简单教程-3-样式
		前言 在上一章 React 简单教程-2-ts 和组件参数 中我们新建的子组件 Displayer 没有样式,显得平平无奇,这一篇我们将给他美化一下. CSS 文件 一般的做法,是在你的组件级目录下新 ... 
- React简单教程-2-ts和组件参数
		前言 在上一章:React 简单教程-1-组件 我们知道了 React 的组件是什么,长什么样,用 js 和 HTML 小小体验了一下组件.在这一章,我们将使用 typescript(简称 ts) 来 ... 
- React简单教程-4.1-hook
		前言 虽然我们简单感受了一下 useState 的用法,但我想你还是对 React 里的 hook 迷迷糊糊的.本文我们将明确下 React 的概念. HOOK 前生今世 在我示例中,写的 React ... 
- React简单教程-1-组件
		前言 React,Facebook开发的前端框架.当时Facebook对市面上的前端框架都不满意,于是自己捣鼓出了React,使用后觉得特别好用,于是就在2013年开源了. 我也用React开发了一个 ... 
- React简单教程-5-使用mock
		前言 一个前后端分离的项目,前端人员需要对接后端的接口.如果在后端的接口没有开发好,或者没有测试版可以对接的情况下,前端人员也不能坐等后端接口写好后再开始开发. 一个项目的,理想情况下接口的规范应该是 ... 
- React简单教程-3.1-样式之使用 tailwindcss
		前言 本文是作为一个额外内容,主要介绍 tailwindcss 的用法 tailwindcss 是一个功能类优先的 CSS 框架,我在以前的文章里有描述为什么使用功能类优先:为什么我在 css 里使用 ... 
- react+redux教程(五)异步、单一state树结构、componentWillReceiveProps
		今天,我们要讲解的是异步.单一state树结构.componentWillReceiveProps这三个知识点. 例子 这个例子是官方的例子,主要是从Reddit中请求新闻列表来显示,可以切换reac ... 
- react 入门教程 阮一峰老师真的是榜样
		- 转自阮一峰老师博客 React 入门实例教程 作者: 阮一峰 日期: 2015年3月31日 现在最热门的前端框架,毫无疑问是 React . 上周,基于 React 的 React Nati ... 
随机推荐
- 常用 adb 命令总结
			1. 显示当前运行的全部模拟器: adb devices 2. 安装应用程序: adb install -r 应用程序.apk 3. 获取模拟器中的文件: a ... 
- JS函数传递参数是是按值传递
			JavaScript在传参的时候只有一种传递方法那就是按值传递(来自红宝书第四版本) 函数在传递参数的时候会把实参的值拷贝过来一份,而基础类型数据值是存在内存中,在拷贝的时候会复制出来一份,而引用类型 ... 
- Spring Framework 学习笔记——核心技术之Spring IOC
			Spring Framework 官网文档学习笔记--核心技术之Spring IOC 官方文档 spring-framework-5.3.9 1. Spring Framework 核心技术 1.1 ... 
- drf过滤和排序及异常处理的包装
			过滤和排序(4星) 查询所有才需要过滤(根据过滤条件),排序(按某个规律排序) 使用前提: 必须继承的顶层类是GenericAPIView 内置过滤类 内置过滤类使用,在视图类中配置,是模糊查询 使用 ... 
- 安卓记账本开发学习day3
			今天发现了新的错误 首先是AS警告杀毒系统对编译运行有影响,我目前只开了火绒,所以只需要在火绒里将SDK文件夹设置为信任即可 第二个错是在编译测试运行的时候,虚拟机能够正常打开,也launch suc ... 
- ArcGIS使用技巧(二)——数据恢复
			新手,若有错误还请指正! ArcGIS工程文件中图层的数据源位置移动之后,会显示红叹号(图1),需要进行数据恢复,就体现出之前所说的勾选"Store relative pathnames t ... 
- Java开发中关于资源路径获取问题
			描述 在开发中经常会读取配置文件,在Web开发中大多数都是在项目路径下.核心的API类或者是Controller异或是jsp页面等,基本都是基于web应用的相对路径,很少去操作绝对路径,但是在客户端. ... 
- Python中的Super详解
			这篇文章我们来介绍一下 super,我相信大部分的人使用 super 都是使用这种方式: # 就是我有一个 class 比如说是 Male,然后继承另外一个 class 比如是 Person,然后我在 ... 
- jmeter脚本编写
			jmeter脚本编写 一.http协议接口编写注意事项 1.请求体为json格式:一定要写请求头Content-Type:application/json 2.json格式文本 2.1 key-val ... 
- ABP应用开发(Step by Step)-上篇
			本文主要通过逐步构建一个CRUD示例程序来介绍 ABP 框架的基础知识.它涉及到应用开发的多个方面.在本章结束时,您将了解ABP 框架的基本开发方式.建议入门人员学习,老手不要浪费您宝贵时间. 创建 ... 
