app.js
import React from 'react'
//函数组件
/**
* 函数组件特点:
* 1.没有this对象
* 2.没有内部状态(Hooks让函数式组件有自己内部的状态)
*/
export default function App(props) {
//必须返回一个合法的JSX虚拟dom元素
return (
<>
//使用props的参数
//不论是vue还是react,组件中的props永远都是只读的,不可以赋值
<div>我是function组件,这是参数:{props.name}</div>
<div>11</div>
</>
)
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
index.js
//1.导入包
import React from "react";
import ReactDOM from "react-dom";
import App from "./01组件定义方式/app";
//2.创建虚拟DOM元素
/**
* 参数1:创建的元素的类型:字符串,表示元素的名称
* 参数2:是一个对象或null,表示当前这个DOM元素的属性
* 参数3:子节点(包括其他虚拟DOM 或 文本子节点)
* 参数n:其他子节点
*
* 注意:JSX语法的本质,还是在运行的时候通过babel插件,被转换成了React.createElement形式来执行的
* class用className代替
* label标签中的for用htmlFor代替
* 必须有唯一的根元素
*/
const myh1 = React.createElement("h1", null, "这是一个大大的h1");
const myDiv = <div>11011</div>;
const list = ["小五郎", "大五郎", "毛利"];
//forEach遍历不返回
//map遍历,并且返回新数组
/**
* 3.使用ReactDOM把虚拟DOM渲染到页面上
* 参数1:要渲染的那个虚拟DOM元素
* 参数2:指定页面上一个容器
*/
ReactDOM.render(
<div>
//传参,函数组件的props接收
<App name='我是传进来的数据'/> {myh1} {myDiv}
<div>
{list.map((item) => (
<div key={item}>
<h5>{item}</h5>
</div>
))}
</div>
</div>,
document.getElementById("root")
);
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
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