博客
关于我
useEffect补充与自定义hooks
阅读量:527 次
发布时间:2019-03-08

本文共 1818 字,大约阅读时间需要 6 分钟。

useEffect

需求:通过useEffect获取到监听值的旧值与新值

  1. 准备一组数据可以被监听到
import React,{   useState} from 'react';		function Child(props){   		let [txt,setTxt] = useState("1");	    	   return {   	                setTxt(target.value)	            }}	        />	}		export default Child
  1. 通过useRef实现绑定
import React,{   useState,useRef} from 'react';function Child(props){       let [txt,setTxt] = useState("1");    let txtRef = useRef(txt);    useEffect(()=>{           console.log(txtRef.current,txt);        txtRef.current = txt;    },[txt]);    return {                   setTxt(target.value)            }}        />}export default Child
  1. 通过useEffect实现监听
import React,{   useState,useEffect,useRef} from 'react';function Child(props){   	let [txt,setTxt] = useState("1");    let txtRef = useRef(txt);        useEffect(()=>{           console.log(txtRef.current,txt);    },[txt]);    return {                   setTxt(target.value)            }}        />}export default Child

浏览器反馈

在这里插入图片描述
我们这个时候已经可以获取到值了,但是每次我们修改完txt,也就是我们的新值出现后,我们的txtRef.current也就是老值是不会发生改变的
浏览器反馈
在这里插入图片描述
4. 所以我们还需要最后一步,将新值输出后,存储在老值内,已达成下一次输出时老值是上一个新值新值是修改后的值

...useEffect(()=>{   	console.log(txtRef.current,txt);	txtRef.current = txt;},[txt]);...

浏览器反馈

在这里插入图片描述

自定义hooks

Hooks使用规则

  1. 只在顶层调⽤Hooks Hooks的调⽤,尽量只在顶层作⽤域进行调用不要在循环,条件或者是嵌套函数中调⽤Hook,否则可能会⽆ ,确保每次组件渲染时都以相同的顺序调⽤Hook。
  2. 只在函数组件调⽤Hooks,React Hooks目前只支持函数组件,所以⼤大家别在class组件或者普通的函数⾥面调⽤Hook钩⼦函数
  3. React Hooks的应用场景在函数组件,自定义hooks

在自定义Hooks中还有一条规则,就是定义时,名字必须以use开头

案例

//自定义hooks组件import React,{   useState} from 'react';function useTitle(title){       return document.title = title}export {   useTitle};// 显示页面import React,{   useState} from 'react';import {   useTitle} from './hooks'function App(){     let [tit,setTit] = useState('App');    useTitle(tit)  return {           setTit(target.value)        target.value = ''      }}    />}export default App;

转载地址:http://hlwiz.baihongyu.com/

你可能感兴趣的文章
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>
Mysql中的 IFNULL 函数的详解
查看>>
mysql中的collate关键字是什么意思?
查看>>
MySql中的concat()相关函数
查看>>
mysql中的concat函数,concat_ws函数,concat_group函数之间的区别
查看>>
MySQL中的count函数
查看>>
MySQL中的DB、DBMS、SQL
查看>>
MySQL中的DECIMAL类型:MYSQL_TYPE_DECIMAL与MYSQL_TYPE_NEWDECIMAL详解
查看>>
MySQL中的GROUP_CONCAT()函数详解与实战应用
查看>>
MySQL中的IO问题分析与优化
查看>>
MySQL中的ON DUPLICATE KEY UPDATE详解与应用
查看>>
mysql中的rbs,SharePoint RBS:即使启用了RBS,内容数据库也在不断增长
查看>>
mysql中的undo log、redo log 、binlog大致概要
查看>>