用于构建用户界面(UI)的 JavaScript 库
版本:16.x / 17.x / 18.x
在想要创建的项目的文件夹内打开控制台输入以下其中一条指令即可。
$ npx create-react-app
# 或
$ yarn create react-app
可以在命令行中使用 npm run
的任务:
src/index.js
文件(16.x、17.x的引入写法):
import React from 'react'
import ReactDOM from 'react-dom'
ReactDOM.render(
<h1>Hello React</h1>,
document.getElementById('root')
)
18.x 的引入写法
const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<h1>Hello, world!</h1>);
<div>Hello { 'world' }</div>
注: { expression }
来嵌入 JS 表达式内容,注意:在 {}
内的 HTML 表达式内容会被转义处理,以避免出现 XSS 攻击。
<div dangerouslySetInnerHTML={{__html: this.state.html}}></div>
function MyComponent(props) {
return (
<div>JSX 表示的 React 元素</div>
)
}
class MyComponent extends React.Component {
// constructor() {}
render() {
// this.props 获取组件接收到的属性
return (
<div>JSX 表示的 React 元素</div>
)
}
}
注意
下载包:
$ npm i prop-types
# 或
$ yarn add prop-types
import PropTypes from 'prop-types'
class MyComponent extends React.Component {
static propTypes = {
prop1: PropTypes.number, // prop1式数字
prop2: PropTypes.array.isRequired, // prop2式数组并且是必填的
}
}
class MyComponent extends React.Component {
static defaultProps = {
prop1: 1,
prop2: 'abc',
prop3: [],
}
}
绑定DOM元素,能够在方法中调用到
import React, {Component} from 'react';
import Children1 from './ components/Children1'
class App extends Component {
myRef=React.createRef()
methods=()=>{
console.log(this.myRef.current)
// 指向div本身
}
render() {
return (
<>
<div ref={this.myRef} onClick={this.methods}>
hello react
</div>
<Children1/>
</>
);
}
}
export default App;
注: 调用 Ref 对象的 current 属性获取关联的数据
父传子:利用 props 传递
子传父:利用 props 来传递函数的引用。父组件中渲染子组件实例时,传递一个函数的引用作为属性值到子组件中,当子组件需要传递数据时,调用在属性中接收到的函数并传递参数即可。要注意函数中 this 指向的问题(可以调用 bind 修改 this 指向,或使用箭头函数定义)
父组件
import React, {Component} from 'react';
import Children1 from './ components/Children1'
class App extends Component {
state={
person:{
name:'jack',
age: '20',
}
}
render() {
return (
<>
<div>
hello react
</div>
<Children1 info={this.state.person}/> // 在这里通过属性的方式传值给子组件
</>
);
}
}
export default App;
import React, {Component} from 'react';
import PropTypes from 'prop-types'
class Children1 extends Component {
static propTypes={
info:PropTypes.object.isRequired
}
show=()=>{
console.log(this.props)
// 控制台打印{info: {…}}
}
render() {
return (
<div>
<div onClick={this.show()}>hello children</div>
<div>{this.props.info.name}</div>
</div>
);
}
}
export default Children1;
import {createContext} from 'react';
// 创建createContext对象
const TestContext=createContext()
// 解构要用到的组件
const {
Provider, // 生产组件
Consumer, // 消费组件
} = TestContext
export {
Provider,
Consumer,
TestContext,
}
import React, {Component} from 'react';
import Children1 from './ components/Children1'
import {Provider} from "./utils/with-context";
class App extends Component {
state={
person:{
name:'jack',
age: '20',
}
}
myRef=React.createRef()
methods=()=>{
console.log(this.myRef.current)
}
render() {
return (
<Provider value={{
person:this.state.person
}}>
<>
<div ref={this.myRef} onClick={this.methods}>
hello react
</div>
<Children1/>
</>
</Provider>
);
}
}
export default App;
import React, {Component} from 'react';
import {Consumer} from "../utils/with-context";
class Children1 extends Component {
render() {
return (
<Consumer>
{
value=>{
const {person} = value
return (
<div>
<div>hello children</div>
<div>{person.name}</div>
</div>
);
}
}
</Consumer>
)
}
}
export default Children1;
import React, {Component} from 'react';
import {Consumer, TestContext} from "../utils/with-context";
class Children1 extends Component {
handelContext=()=>{
console.log(this.context) //{person: {…}}
}
render() {
TestContext.displayName='rose'
return (
<Consumer>
{
value=>{
const {person} = value
return (
<div>
<div onClick={this.handelContext}>hello children</div>
<div>{person.name}</div> // jack
<div>{TestContext.displayName}</div> // rose
</div>
);
}
}
</Consumer>
)
}
}
Children1.contextType=TestContext // 定义类的静态属性,这样类中就能访问context
export default Children1;
1.挂载阶段
当组件实例被创建并插入 DOM 中时
2.更新阶段
当组件的 props 或 state 发生变化时会触发更新