博客
关于我
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底层概述—5.InnoDB参数优化
查看>>
MySQL底层概述—6.索引原理
查看>>
MySQL底层概述—7.优化原则及慢查询
查看>>
MySQL底层概述—8.JOIN排序索引优化
查看>>
MySQL底层概述—9.ACID与事务
查看>>
Mysql建立中英文全文索引(mysql5.7以上)
查看>>
mysql建立索引的几大原则
查看>>
Mysql建表中的 “FEDERATED 引擎连接失败 - Server Name Doesn‘t Exist“ 解决方法
查看>>
mysql开启bin-log日志,用于canal同步
查看>>
MySQL开源工具推荐,有了它我卸了珍藏多年Nactive!
查看>>
MySQL异步操作在C++中的应用
查看>>
MySQL引擎讲解
查看>>
Mysql当前列的值等于上一行的值累加前一列的值
查看>>
MySQL当查询的时候有多个结果,但需要返回一条的情况用GROUP_CONCAT拼接
查看>>
MySQL必知必会(组合Where子句,Not和In操作符)
查看>>
MySQL必知必会总结笔记
查看>>
MySQL快速入门
查看>>
MySQL快速入门——库的操作
查看>>
mysql快速复制一张表的内容,并添加新内容到另一张表中
查看>>
mysql快速查询表的结构和注释,字段等信息
查看>>