Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/bramblex/react-hooks

React Hooks API 在 16.6 上面的模拟实现
https://github.com/bramblex/react-hooks

Last synced: about 1 month ago
JSON representation

React Hooks API 在 16.6 上面的模拟实现

Awesome Lists containing this project

README

        

# react-hooks

React Hooks API 在低版本 React 16.6 下面的一个实现,可以在不升级 React 版本的前提下体验新的 React Hooks API。
## Install

```
npm install blx-react-hooks
# or
yarn add blx-react-hooks
```

## Usage
在声明函数式组件的时候,通过用 `withHooks()` 函数封装就可以就使用 Hooks API 了。与 React 的 Hooks API 只差了需要 `withHooks()` 函数进行封装。

```JSX
import {withHooks, useState} from 'blx-react-hooks'

// 如果想在调试的时候看到组件名,定义function的时候必须要定义成一个命名函数
const Counter = withHooks(function Counter({title, initCount}) {
const [count, setCount] = useState(initCount)
return (


{title}


setCount(count - 1)}> -
Count: {count}
setCount(count + 1)}> +

)
})
```

完整示例 [https://github.com/bramblex/react-hooks/blob/master/example.html](https://github.com/bramblex/react-hooks/blob/master/example.html)

## API

* withHooks
* useState / useReducer
* useEffect / useLayoutEffect
* useContext
* useRef / useImperativeMethods
* useMemo / useCallback

## Document
API 的文档直接参见 React Hooks API 的文档:[https://reactjs.org/docs/hooks-intro.html](https://reactjs.org/docs/hooks-intro.html)