博客
关于我
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/

你可能感兴趣的文章
nodejs libararies
查看>>
vue3+element-plus 项目中 el-switch 刷新后自动触发change?坑就藏在这里!
查看>>
nodejs npm常用命令
查看>>
nodejs npm常用命令
查看>>
Nodejs process.nextTick() 使用详解
查看>>
NodeJS yarn 或 npm如何切换淘宝或国外镜像源
查看>>
nodejs 中间件理解
查看>>
nodejs 创建HTTP服务器详解
查看>>
nodejs 发起 GET 请求示例和 POST 请求示例
查看>>
NodeJS 导入导出模块的方法( 代码演示 )
查看>>
nodejs 开发websocket 笔记
查看>>
nodejs 的 Buffer 详解
查看>>
NodeJS 的环境变量: 开发环境vs生产环境
查看>>
nodejs 读取xlsx文件内容
查看>>
nodejs 运行CMD命令
查看>>
Nodejs+Express+Mysql实现简单用户管理增删改查
查看>>
nodejs+nginx获取真实ip
查看>>
nodejs-mime类型
查看>>
NodeJs——(11)控制权转移next
查看>>
NodeJS、NPM安装配置步骤(windows版本)
查看>>