Skip to content

React自定义Hook实现Vue中的watch功能

License

Notifications You must be signed in to change notification settings

leerle/use-watch-hook

 
 

Repository files navigation

use-watch-hook

A React Hook that use to call the callback when the dep changed

通过React自定义Hook实现Vue中的watch功能,当依赖发生变化的时候,执行回调函数,并且支持了immediate和stop功能。

Stability

Coverage Status

Doc

https://sl1673495.github.io/use-watch-hook

Usage

npm i use-watch-hook -S
import React, { useState } from 'react';
import useWatch from '../src'
import './index.css'

const App: React.FC = () => {
  const [prev, setPrev] = useState()
  const [count, setCount] = useState(0);

  const stop = useWatch(count, (prevCount) => {
    console.log('prevCount: ', prevCount);
    console.log('currentCount: ', count);
    setPrev(prevCount)
  })

  const add = () => setCount(prevCount => prevCount + 1)

  return (
    <div>
      <p> 当前的count是{count}</p>
      <p> 前一次的count是{prev}</p>
      {count}
      <button onClick={add} className="btn">+</button>
      <button onClick={stop} className="btn">停止观察旧值</button>
    </div>
  )
}

export default App

LICENSE

MIT

About

React自定义Hook实现Vue中的watch功能

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 100.0%