react.js 从零开始(一)

React.js 是一个由 Facebook 推出的用于构建用户界面的 JavaScript 库。它通过组件化构建出可复用的 UI 组件,可大大提高代码的可读性、可维护性、可扩展性和可测试性,被广泛应用于前端开发中。

本文将从 React.js 的基础入门开始,分别介绍 React.js 的组件、生命周期、状态、属性、事件等常用功能,并通过简单的实例讲解如何使用 React.js 在网页中构建动态的交互式用户界面。

## 安装和使用 React.js

首先,我们需要在本地环境中安装 React.js。React.js 可以通过 npm 安装,在命令行中执行以下命令:

```

npm install react react-dom --save

```

该命令将安装 React.js 和 React DOM,其中 React.js 是 React 核心库,React DOM 是操作 HTML 文档的库。

安装完成以后,在 HTML 页面中引用 React.js 和 React DOM:

```html

React.js Demo

```

其中 `https://cdn.bootcdn.net/ajax/libs/react/17.0.2/umd/react.development.js` 和 `https://cdn.bootcdn.net/ajax/libs/react-dom/17.0.2/umd/react-dom.development.js` 分别是 React.js 和 React DOM 的 CDN 地址,`./index.js` 是我们将在下面创建的 JavaScript 文件。

## 创建 React 组件

React.js 的核心思想是组件化,开发者可以将一个应用程序拆分成多个可重用的组件。在 React 中,一个组件就是一个 JavaScript 类,可以用 ES6 的 class 关键字来定义,也可以使用函数式组件。

### 类组件

类组件是基于 ES6 class 实现的组件,继承自 React.Component。定义一个类组件,首先需要引入 React:

```javascript

import React from 'react';

```

然后,可以使用 class 关键字来定义一个类组件:

```javascript

class Greeting extends React.Component {

render() {

return

Hello, {this.props.name}!

;

}

}

```

上面的代码定义了一个名为 Greeting 的组件,在 render 方法中返回一个 h1 标题,标题内容为 `Hello, {this.props.name}!`。其中,`this.props.name` 表示传入的 props 属性中的 name 值。

组件的 props 属性是一个包含传入组件的所有属性的对象。在上面的代码中,我们用了 props 属性传入了一个名为 name 的属性。

创建一个类组件的实例,可以使用 React.createElement 方法:

```javascript

const element = React.createElement(Greeting, { name: 'React' });

```

在上面的代码中,我们创建了一个名为 element 的元素,调用了 `React.createElement` 方法并传入 Greeting 类组件和名为 name 且值为 'React' 的 props。这样就定义了一个名为 Greeting 的组件并给它传入了 name 属性。

最后,将元素渲染到页面中:

```javascript

ReactDOM.render(element, document.getElementById('root'));

```

在上面的代码中,我们将元素 element 渲染到页面中,将其插入到 id 为 root 的 div 中。

### 函数式组件

函数式组件是一种简单的组件,使用函数来定义。函数式组件没有生命周期和状态等复杂的功能,通常用于简单的组件,比如用于展示静态内容的组件。

函数式组件的定义方式如下:

```javascript

function Greeting(props) {

return

Hello, {props.name}!

;

}

```

上面的代码与类组件中的代码相似,不同之处在于定义方式不同。

类组件和函数式组件在使用时没有本质区别,都可以将它们当作一个标签来使用:

```javascript

const element = ;

ReactDOM.render(element, document.getElementById('root'));

```

## React 组件的生命周期

在 React 组件中,有许多生命周期方法可以在组件的不同阶段执行特定的逻辑。生命周期方法可以帮助组件在正确的时间完成特定的任务,一般分为三个阶段:挂载阶段、更新阶段和卸载阶段。

### 挂载阶段

在组件挂载到页面之前,React.js 会调用以下生命周期方法:

#### constructor(props)

constructor 方法是 React.js 中的一个构造函数,可以在组件创建时进行初始化操作。在构造函数种可以使用 this.state 对象对组件进行初始化:

```javascript

class Counter extends React.Component {

constructor(props) {

super(props);

this.state = {

count: 0

};

}

}

```

在上面的代码中,我们定义了一个名为 Counter 的组件,在 constructor 中初始化了一个为 0 的计数器。

#### componentWillMount

componentWillMount 方法在渲染之前被执行,只执行一次。它可以在组件经历过 constructor 方法后,但是还没渲染完成时进行一些状态的设置和初始化操作。一般情况下,我们尽量在 constructor 中进行初始化,而不是在 componentWillMount 中,因为它存在一些隐含的副作用,在将来的版本中可能会被废弃。

#### render

render 方法是 React.js 组件必须的生命周期方法之一,用于指定组件在渲染时应该展示什么样的界面。它返回的是一个 React 元素,可以是一个 HTML 标签或者其他组件。

```javascript

class Counter extends React.Component {

constructor(props) {

super(props);

this.state = {

count: 0

};

}

render() {

return

{this.state.count}

;

}

}

```

在上面的代码中,我们定义了一个名为 Counter 的组件,在 render 方法中返回了一个 h1 标题,标题的内容为 this.state.count 的值。

#### componentDidMount

componentDidMount 方法在组件挂载后被执行,只运行一次。它可以在组件挂载后执行一些需要操作 DOM 的操作,比如获取元素的高度或者宽度等。

### 更新阶段

当组件的父组件重新渲染时,或者当组件需要更新时,React.js 会调用一系列的生命周期方法。更新阶段中主要包括以下方法:

#### componentWillReceiveProps(nextProps)

componentWillReceiveProps 方法是在组件将要接收新的属性值时被执行的方法。它接收一个 nextProps 参数,其中包含了新的属性值,可以在这个方法中根据新的属性值来更新组件的状态。

#### shouldComponentUpdate(nextProps, nextState)

shouldComponentUpdate 方法决定了组件是否重新渲染。它接收两个参数,nextProps 和 nextState,分别是组件的下一个属性和下一个状态。在这个方法中,我们可以根据当前组件的状态和属性值来判断当前组件是否需要重新渲染。一般情况下,我们使用浅层比较进行判断,以避免组件的不必要的重新渲染。

```javascript

shouldComponentUpdate(nextProps, nextState) {

if (this.props.color === nextProps.color && this.state.count === nextState.count) {

// 如果颜色和计数器的值都没有改变,则不需要重新渲染

return false;

}

// 否则需要重新渲染

return true;

}

```

在上面的代码中,我们使用 this.props.color 和 nextProps.color 进行比较,使用 this.state.count 和 nextState.count 进行比较,如果两者都没有改变,则认为不需要重新渲染。

#### componentWillUpdate

componentWillUpdate 方法在组件即将重新渲染时被执行。在这个方法中,我们可以执行一些在重新渲染前必须的操作,比如获取 this.props 或 this.state 中的值等。

#### render

render 方法在更新阶段与挂载阶段中是相同的,用于指定组件应该在重新渲染时展示什么样的界面。

#### componentDidUpdate

componentDidUpdate 方法在组件重新渲染完成后被执行。在这个方法中,我们可以执行一些需要操作 DOM 的操作,也可以获取到 this.props 和 this.state 的最新值。

### 卸载阶段

当组件从页面中移除时,React.js 会调用以下生命周期方法:

#### componentWillUnmount

componentWillUnmount 方法仅被执行一次,即在组件被卸载时执行。它可以用于执行一些必要的清理操作,比如取消定时器、取消订阅等。

## React 组件的状态和属性

在 React.js 组件中,有两种重要的概念,分别是状态和属性。

### 状态

状态是组件自己管理和维护的数据,它存储了组件的内部数据。状态一般在构造函数中进行初始化,并在组件内部进行修改。每当状态发生变化时,React.js 就会自动重新渲染组件,以反映最新的状态变化。

```javascript

class Counter extends React.Component {

constructor(props) {

super(props);

this.state = {

count: 0

};

}

render() {

return

{this.state.count}

;

}

}

```

在上面的代码中,我们定义了一个计数器组件,并在 constructor 中初始化了一个为 0 的计数器状态,然后在 render 方法里展示了这个状态的值。

当我们需要更新状态时,可以调用 `setState` 方法,它会自动重新渲染组件并反映最新的状态变化。

```javascript

class Counter extends React.Component {

constructor(props) {

super(props);

this.state = {

count: 0

};

this.handleClick = this.handleClick.bind(this);

}

handleClick() {

this.setState({ count: this.state.count + 1 });

}

render() {

return (

{this.state.count}

);

}

}

```

在上面的代码中,我们添加了一个名为 handleClick 的方法,其中调用了 `setState` 方法来更新计数器的值。然后,在 render 方法中添加了一个按钮,并给按钮绑定了一个点击事件,当按钮被点击时,调用 handleClick 方法更新计数器的值。

### 属性

属性是从父组件传递给子组件的值,子组件的状态不应该影响父组件。在父组件中改变属性值,可以引起子组件的属性值的变化,但不能影响到子组件的状态。例如:

```javascript

class App extends React.Component {

constructor(props) {

super(props);

this.state = {

name: 'world'

};

this.handleClick = this.handleClick.bind(this);

}

handleClick() {

this.setState({ name: 'React' });

}

render() {

return (

);

}

}

function Greeting(props) {

return

Hello, {props.name}!

;

}

```

在上面的代码中,我们在 App 组件中定义了一个名为 name 的状态,然后将这个状态的值传递给了 Greeting 子组件的 name 属性。当点击按钮时,通过调用 `setState` 方法改变了 App 组件的状态,并更新了 Greeting 子组件的 name 属性,从而重新渲染了 Greeting 组件和按钮。

## React 组件的事件处理

在 React.js 中,事件处理方式与原生 JavaScript 相似。区别在于,在 React.js 中我们需要用到 JSX 来表示事件处理函数,同时需要绑定事件处理函数的 this 指向,以方便在函数内使用 this.state 和 this.props。

### 在类组件中绑定事件

在类组件中,可以使用 ES6 class 绑定事件处理函数。通常将组件的方法绑定到组件实例上,以便在组件事件处理函数中引用 this.props 和 this.state。

```javascript

class Button extends React.Component {

constructor(props) {

super(props);

this.handleClick = this.handleClick.bind(this);

}

handleClick() {

console.log('Button clicked');

}

render() {

return (

);

}

}

```

在上面的代码中,我们定义了一个名为 Button 的组件,并在 constructor 中将 handleClick 方法绑定到了组件实例上,然后在 button 的 onClick 事件中引用了该方法,并将 label 属性的值展示出来。当点击按钮时,控制台会输出 'Button clicked'。

### 在函数式组件中绑定事件

在函数式组件中,可以使用类似于 HTML 标签的方式来绑定事件处理函数。同时,为了引用 this.props 和 this.state,可以使用 destructuring 语法。

```javascript

function Button(props) {

function handleClick() {

console.log('Button clicked');

}

return (

);

}

```

在上面的代码中,我们定义了一个名为 Button 的组件,编写了一个 handleClick 的函数来处理按钮点击事件,然后将该函数绑定在 button 元素的 onClick 事件上,并使用 destructuring 语法引用了组件的 props 属性中的 label 值。当点击按钮时,控制台会输出 'Button clicked'。

## 结论

通过本文的介绍,我们了解到了 React.js 的组件化思想,以及 React 组件的生命周期、状态、属性、事件等常用功能。同时,我们也介绍了如何在 React.js 中创建组件、渲染组件、更新组件、卸载组件等。

React.js 是一个非常强大的前端框架,可以大大提高开发效率和代码可维护性。希望本文能对 React.js 的学习有所帮助,并为你的前端开发之路开启新的方向。

壹涵网络我们是一家专注于网站建设、企业营销、网站关键词排名、AI内容生成、新媒体营销和短视频营销等业务的公司。我们拥有一支优秀的团队,专门致力于为客户提供优质的服务。

我们致力于为客户提供一站式的互联网营销服务,帮助客户在激烈的市场竞争中获得更大的优势和发展机会!

点赞(89) 打赏

评论列表 共有 0 条评论

暂无评论
立即
投稿
发表
评论
返回
顶部