-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.js
59 lines (59 loc) · 1.23 KB
/
main.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
import { createElement, render, useState } from './mini-react'
let inputValue = 'wmb'
let showInput = true
const inputElement = createElement(
'input',
{
value: inputValue,
oninput: (e) => {
inputValue = e.target.value
renderer()
}
},
)
const buttonElement = createElement(
'button',
{
value: inputValue,
onclick: (e) => {
showInput = false
renderer()
}
},
'删除我自己'
)
const App = ({ name }) => {
return createElement('div', {
title: "foo",
},
'你好我是app'
)
}
const AppElement = createElement(App, {
name: "foo",
})
const Counter = () => {
const [ count, setCount ] = useState(0)
return createElement('span', {
ffz: 123,
onclick: () => setCount(() => count+1),
}, String(count))
}
const CounterElement = createElement(Counter, {nima: 3444})
function renderer () {
const children = showInput ? [ inputElement, buttonElement ]: [ inputElement ]
const element = createElement(
'h1',
{
title: 'foo'
},
'Hello' + inputValue,
AppElement,
CounterElement,
...children
)
console.log('element', element)
const container = document.getElementById("root")
render(element, container)
}
renderer()