IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> React之组件的生命周期 -> 正文阅读

[JavaScript知识库]React之组件的生命周期

生命周期

人一生有不同的阶段,React组件就好比人的一生,有不同的阶段,不同的阶段可以干不同的事。
组件从创建到死亡会经历一些特定的阶段
React组件中包含一系列钩子函数,会在特定的时刻调用
我们在定义组件时,会在特定的生命周期回调函数中,做特定的工作

引出生命周期

实例

一段文字内容一直渐变,按下按钮所有内容消失

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="test"></div>

    <script src="../js/react.development.js"></script>
    <script src="../js/react-dom.development.js"></script>
    <script src="../js/babel.min.js"></script>
    <script src="../js/prop-types.js"></script>
    <script type="text/babel">
      class Life extends React.Component {

        state = {opacity:0.5}

        death = () => {
            //卸载组件
            ReactDOM.unmountComponentAtNode(document.getElementById("test"))

        }

        //组件挂载完毕
        componentDidMount() {
            this.timer = setInterval(() => {
                let {opacity} = this.state
                opacity -= 0.1
                if(opacity <= 0)opacity = 1
                this.setState({opacity})
            }, 200)
        }

        //组件将要卸载
        componentWillUnmount() {
            //清除定时器
            clearInterval(this.timer)
        }

        //render调用的时机:初始化渲染,状态更新之后
        render() {
            return (
                <div>
                    <h2 style={{opacity:this.state.opacity}}>React学不会怎么办</h2>
                    <button onClick={this.death}>不活了</button>
                </div>
            )
        }
      }
      ReactDOM.render(<Life/>, document.getElementById("test"))
    </script>
</body>
</html>

运行结果:
在这里插入图片描述
字会渐变,按下按钮内容会消失

React生命周期(旧)

在这里插入图片描述

实例1

显示数字,点击按钮便加上1

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="test"></div>

    <script src="../js/react.development.js"></script>
    <script src="../js/react-dom.development.js"></script>
    <script src="../js/babel.min.js"></script>
    <script src="../js/prop-types.js"></script>
    <script type="text/babel">
        class Count extends React.Component {

            constructor(props) {
                console.log("constructor")
                super(props)
                //初始化状态
                this.state = {count:0}
            }

            //组件将要挂载的钩子
            componentWillMount() {
                console.log("componentWillMount")
            }

            //组件挂在完毕的钩子
            componentDidMount() {
                console.log("componentDidMount")
            }

            add = () => {
                const {count} = this.state
                this.setState({count:count+1})
            }

            //卸载组件按钮
            death = () => {
                ReactDOM.unmountComponentAtNode(document.getElementById("test"))
            }

            force = () => {
                this.forceUpdate();
            }

            //控制组件更新的阀门
            shouldComponentUpdate(){
                console.log("shouldComponentUpdate");
                return true
            }

            //组件将要更新的钩子
            componentWillUpdate(){
                console.log("componentWillUpdate")
            }

            //组件更新完的钩子
            componentDidUpdate() {
                console.log("componentDidUpdate")
            }

            render() {
                console.log("render")
                const {count} = this.state
                return (
                    <div>
                        <h2>当前求和为{count}</h2>
                        <button onClick={this.add}>点我+1</button>
                        <button onClick={this.death}>卸载组件</button>
                        <button onClick={this.force}>强制更新</button>
                        </div>
                )
            }
        }
        ReactDOM.render(<Count/>, document.getElementById("test"))

    </script>
</body>
</html>

运行结果
在这里插入图片描述
这样一些生命周期方法的运行顺序就一目了然了。

实例2

关于使用父组件render

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="test"></div>

    <script src="../js/react.development.js"></script>
    <script src="../js/react-dom.development.js"></script>
    <script src="../js/babel.min.js"></script>
    <script src="../js/prop-types.js"></script>
    <script type="text/babel">
        //父组件A
        class A extends React.PureComponent {
            state = {carname:"奔驰"}
            changeCar = () => {
                this.setState({carname:"奥迪"})
            }

            render(){
                return (
                    <div>
                        <div>我是A组件</div>
                        <button onClick={this.changeCar}>换车</button>
                        <B carname={this.state.carname}/>
                    </div>
                )
            }
        }
        //子组件B
        class B extends React.PureComponent {
            //组件将要接受新的props的钩子
            componentWillReceiveProps(){
                console.log("B_componentWillReceiveProps")
            }

            //控制组件更新的阀门
            shouldComponentUpdate(){
                console.log("shouldComponentUpdate");
                return true
            }

            //组件将要更新的钩子
            componentWillUpdate(){
                console.log("componentWillUpdate")
            }

            //组件更新完的钩子
            componentDidUpdate() {
                console.log("componentDidUpdate")
            }


            render(){
                return (
                    <div>我是B组件,接收到的车是:{this.props.carname}</div>
                )
            }
        }
        ReactDOM.render(<A/>, document.getElementById("test"))
    </script>
</body>
</html>

在这里插入图片描述
按一下按钮组件的内容改变,也可看感受到组件生命周期

总结

在这里插入图片描述
其中比较重要的勾子:
componentDidMount()一般做初始化
componentWillUnmount()一般做收尾的事
render必备

即将废弃的勾子:
componentWillMount
componetWillReceiveProps
componetWillUpdate

React生命周期(新)

在这里插入图片描述
简单来说就是去了三个Will,加了两个Update,新加的其实也没什么大用,不过getSnapshotBeforeUpdate还是可以用一下的

实例

新闻一直滚动,移动滚动条,使得新闻相对静止展示

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .list{
            width: 200px;
            height: 150px;
            background-color: skyblue;
            overflow: auto;
        }
        .news{
            height:30px;
        }
    </style>
</head>
<body>
    <div id="test"></div>

    <script src="../new_js/react.development.js"></script>
    <script src="../new_js/react-dom.development.js"></script>
    <script src="../new_js/babel.min.js"></script>
    <script src="../new_js/prop-types.js"></script>
    <script type="text/babel">
        class NewsList extends React.Component {
            state = {newsArr:[]}
            componentDidMount() {
                setInterval(()=>{
                    //获取原状态
                    const {newsArr} = this.state
                    //模拟一条新闻
                    const news = "新闻" + (newsArr.length + 1)
                    //更新状态
                    this.setState({newsArr:[news,...newsArr]})
                }, 1000);
            }


            getSnapshotBeforeUpdate(){
                return this.refs.list.scrollHeight
            }

            componentDidUpdate(preProps, PreState, height){
                this.refs.list.scrollTop += this.refs.list.scrollHeight - height
            }

            render() {
                return (
                    <div className="list" ref="list">
                        {this.state.newsArr.map((n, index)=>{
                            return <div key={index} className="news">{n}</div>
                        })
                        }
                    </div>
                )
            }
        }
        ReactDOM.render(<NewsList/>, document.getElementById("test"))
    </script>
</body>
</html>

运行结果:
在这里插入图片描述
新闻一直增加,但是显示相对静止。

总结

在这里插入图片描述
废除了三个,新加的两个目前看来没什么大用。

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-08-19 18:55:10  更:2022-08-19 18:55:19 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 9:47:24-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码