-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMyReact.js
63 lines (48 loc) · 1.18 KB
/
MyReact.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
import { createElement, render } from './Utils'
let _states = []
let statesIdx = 0
let _deps = []
let depsIdx = 0
let _refs = []
let refIndex = 0
export const useState = (initState) => {
_states[statesIdx] = _states[statesIdx] || initState;
let myIndex = statesIdx
const setState = (newState, callback=null) => {
_states[myIndex] = newState;
if(callback) {
callback()
}
}
statesIdx++
return [_states[myIndex], setState]
}
export const useEffect = (cb, depArray) => {
const oldDeps = _deps[depsIdx]
let hasChanged = true
if (oldDeps) {
hasChanged = _deps ? !depArray.every((el, i) => el === _deps[i]) : true
}
if (hasChanged) {
cb()
}
_deps[depsIdx] = depArray
depsIdx++
}
export const useRef = (val) => {
const myIndex = refIndex
if(!_refs[myIndex]) {
_refs[myIndex] = { current: val }
refIndex++
}
return _refs[myIndex]
}
function workLoop () {
statesIdx = 0
depsIdx = 0
refIndex = 0
render(_states, _deps)()
setTimeout(workLoop, 300)
}
setTimeout(workLoop, 100)
export default { render: render(_states, _deps), createElement }