day03--react中对state的理解

一、react中的state

1.state是组件对象最重要的属性,值是对象(可以包含多个key-value的组合)

2.组件被称为"状态机",通过更新组件的state来更新对应的页面显示(重新渲染组件)
注意:

(1)组件中的render方法中的this为组件实例对象

(2)组件自定义的方法中this为undefined,如何解决?

a.强制绑定this:通过函数对象的bind()

b.箭头函数

(3) 状态数据,不能直接修改或更新。

函数式组件:this为undefined

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>hello_react</title>
</head>

<body>
    <!-- 准备好一个容器 -->
    <div id="test"></div>
    <!-- 引入react核心库 -->
    <script type="text/javascript" src="/react-development.js"></script>
    <!-- 引入react-dom,用于支持react操作DOM -->
    <script type="text/javascript" src="/react-dom-development.js"></script>
    <!-- 引入babel,用于将jsx转为js -->
    <script type="text/javascript" src="/babel.min.js"></script>
    <script type="text/babel">
        // 1.创建函数式组件
        function Demo() {
            console.log(this);//undefined
            return <h2>我是用函数定义的组件</h2>
        }
        // 2.渲染组件到页面
        ReactDOM.render(<Demo />, document.getElementById('test'))
        /**
         * 执行了ReactDOM.render(<MyComponent/>.....)之后,发生了什么?
         * 1.React解析组件标签,找到MyComponent组件。
         * 2.发现组件是使用函数定义的,随后调用该函数,将返回的虚拟DOM转为真实DOM,随后呈现在页面中。
         * 
         */
    </script>
</body>

</html>

类式组件

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>hello_react</title>
</head>

<body>
    <!-- 准备好一个容器 -->
    <div id="test"></div>
    <!-- 引入react核心库 -->
    <script type="text/javascript" src="/react-development.js"></script>
   <!-- 引入react-dom,用于支持react操作DOM -->
    <script type="text/javascript" src="/react-dom-development.js"></script>
    <!-- 引入babel,用于将jsx转为js -->
    <script type="text/javascript" src="/babel.min.js"></script>
    <script type="text/babel">
        // 1.创建类式组件
        class MyComponent extends React.Component {
            render() {
                console.log(this);
                // render是放在哪里的?MyComponent的原型对象上,供实例使用。
                // render()中的this指向的是MyComponent组件实例对象
                return <h2>我是用函数定义的组件</h2>
            }
        }
        // 2.渲染组件到页面
        ReactDOM.render(<MyComponent/>,document.getElementById('test'))
        /**
         * 执行了ReactDOM.render(<MyComponent/>.....)之后,发生了什么?
         * 1.React解析组件标签,找到MyComponent组件。
         * 2.发现组件是使用类定义的,随后new出来该类的实例,并通过该实例调用原型链上的render方法
         * 3.将render返回的虚拟DOM转为真实DOM,随后呈现在页面中。
         */
    </script>
</body>

</html>

类式组件的this

相关推荐
呆呆敲代码的小Y9 分钟前
2025年多家海外代理IP实战案例横向测评,挑选适合自己的
前端·产品
q***37513 分钟前
爬虫学习 01 Web Scraper的使用
前端·爬虫·学习
v***56522 分钟前
Spring Cloud Gateway
android·前端·后端
b***594326 分钟前
分布式WEB应用中会话管理的变迁之路
前端·分布式
q***216029 分钟前
Spring Boot项目接收前端参数的11种方式
前端·spring boot·后端
顾安r1 小时前
11.21 脚本 网页优化
linux·前端·javascript·算法·html
S***H2831 小时前
JavaScript原型链继承
开发语言·javascript·原型模式
q***T5832 小时前
GitHub星标20万+的React项目,学习价值分析
前端·学习·react.js
合作小小程序员小小店2 小时前
web开发,在线%药店管理%系统,基于Idea,html,css,jQuery,java,ssm,mysql。
java·前端·mysql·jdk·html·intellij-idea
ClassOps2 小时前
Chrome 插件记录
前端·chrome