-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathapp.js
More file actions
95 lines (95 loc) · 3.48 KB
/
app.js
File metadata and controls
95 lines (95 loc) · 3.48 KB
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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
let myAppState = [];
let myAppStateCursor = 0;
const resourceCache = {};
const createResource = (asyncTask, key) => {
if (resourceCache[key])
return resourceCache[key];
throw { promise: asyncTask(), key };
};
const React = {
createElement: (tag, props, ...children) => {
if (typeof tag === "function") {
try {
return tag(props, ...children);
}
catch ({ promise, key }) {
promise.then((value) => {
resourceCache[key] = value;
reRender();
});
promise.catch((error) => {
console.error(error);
});
return { tag: "h2", props: null, children: ["loading your image"] };
}
}
const el = { tag, props, children };
return el;
},
};
const useState = (initialState) => {
const stateCursor = myAppStateCursor;
myAppState[stateCursor] = myAppState[stateCursor] || initialState;
console.log(`${stateCursor}에 있는 useState는 ${myAppState[stateCursor]}로 초기화되었습니다.`);
const setState = (newState) => {
console.log(`setState는 ${stateCursor}에 있는 newState와 함께 호출되었습니다.`, newState);
myAppState[stateCursor] = newState;
reRender();
};
myAppStateCursor++;
console.log(`stateDump`, myAppState);
return [myAppState[stateCursor], setState];
};
const reRender = () => {
console.log("reRendering");
const rootNode = document.getElementById("myapp");
rootNode.innerHTML = "";
myAppStateCursor = 0;
render(React.createElement(App, null), rootNode);
};
const render = (el, container) => {
let domEl;
if (typeof el === "string") {
domEl = document.createTextNode(el);
container.appendChild(domEl);
return;
}
domEl = document.createElement(el.tag);
let elProps = el.props ? Object.keys(el.props) : null;
if (elProps && elProps.length > 0) {
elProps.forEach((prop) => (domEl[prop] = el.props[prop]));
}
if (el.children && el.children.length > 0) {
el.children.forEach((node) => render(node, domEl));
}
container.appendChild(domEl);
};
const photoURL = "https://placehold.co/600x400";
const getMyAwesomePic = () => {
return new Promise((resolve, reject) => {
setTimeout(() => {
resolve(photoURL);
}, 1500);
});
};
const App = () => {
const [name, setName] = useState("FrogSoo");
const [count, setCount] = useState(0);
const photo = createResource(getMyAwesomePic, "photo");
return (React.createElement("div", { draggable: true },
React.createElement("h2", null,
"Hello ",
name,
"!"),
React.createElement("p", null, "I am a paragraph"),
React.createElement("input", { type: "text", placeholder: "\uD14D\uC2A4\uD2B8\uB97C \uC785\uB825\uD574\uC8FC\uC138\uC694", value: name, onchange: (e) => setName(e.target.value) }),
React.createElement("h2", null,
"Counter value: ",
count),
React.createElement("button", { onclick: () => setCount(count + 1) }, "+1"),
React.createElement("button", { onclick: () => setCount(count - 1) }, "-1"),
React.createElement("h2", null, "Photo Album"),
React.createElement("img", { src: photo, alt: "My Awesome Pic" })));
};
render(React.createElement(App, null), document.getElementById("myapp"));
//# sourceMappingURL=app.js.map