React--》React组件的三大核心属性

news2024/12/23 17:54:45

目录

state

事件绑定

props

函数式组件使用props

refs


state

state是组件对象最重要的属性,值是对象(可以包含多个 key-value的组合);组件被称为“状态机”,通过更新组件来对应页面显示(重新渲染组件),也就是有状态组件:

事件绑定

在React中进行事件绑定来渲染数据通过使用以下方式进行:

<body>
  <div id="root"></div>
  <!-- 引入react核心库 -->
  <script src="./node_modules/react/umd/react.development.js"></script>
  <!-- 引入react-dom,用于支持react操作dom -->
  <script src="./node_modules/react-dom/umd/react-dom.development.js"></script>
  <!-- 引入babel,用于将jsx转为js -->
  <script src="https://unpkg.com/@babel/standalone/babel.min.js"></script>

  <script type="text/babel">
    // 创建组件
    class Weather extends React.Component {
      constructor(props){
        super(props)
        this.state = {isHot:true,wind:'微风'}
        // 将changeWeather的this指向Weather的实例对象上
        this.changeWeather = this.changeWeather.bind(this)
      }

      render(){
        // 读取状态
        const {isHot,wind} = this.state
        return (
          <div>
            <h1>今天天气很{isHot ? '炎热' : '寒冷'},{wind}</h1>
            <button onClick={this.changeWeather}>点击切换天气</button>  
          </div>
        )
      }
      changeWeather(){
        // 获取原来的isHot的值
        const isHot = this.state.isHot
        // 注意:状态必须通过 setState 进行更新,且更新是一种合并不是替换
        this.setState({isHot:!isHot})

        // 禁止直接对state状态进行修改
        // this.state.isHot = !isHot 这种写法是错误的
      }
    }
    // 渲染页面到组件
    ReactDOM.render(<Weather/>,document.getElementById('root'))
  </script>
</body>

虽然能实现效果,但是未免有些过于繁琐,要知道我们在创建类的时候,如果不是通过new出来的实例传入的数据,我们完全可以把固定的数据写在构造器的外面,如下:

<script>
  class person {
    constructor(name,age){
      this.name = name
      this.age = age
    }
    // 类里面可以直接写赋值语句
    gender = '男'
  }
  const p1 = new person('张三',18)
  console.log(p1)
</script>

所以我们也可以将state状态写在构造器外面,构造器可以直接省略,通过箭头函数的this指向外层的this来达到修改state中this数据的目的:

<script type="text/babel">
  // 创建组件
  class Weather extends React.Component {
    // 初始化状态
    state = {isHot:true,wind:'微风'}
    render(){
      // 读取状态
      const {isHot,wind} = this.state
      return (
        <div>
          <h1>今天天气很{isHot ? '炎热' : '寒冷'},{wind}</h1>
          <button onClick={this.changeWeather}>点击切换天气</button>  
        </div>
      )
    }
    // 自定义方法---要用赋值语句的形式+箭头函数
    changeWeather = ()=> {
      const isHot = this.state.isHot
      this.setState({isHot:!isHot})
    }
  }
  // 渲染页面到组件
  ReactDOM.render(<Weather/>,document.getElementById('root'))
</script>

注意

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

2)组件自定义的方法中this为undefined,强制绑定this可以通过函数对象的bind()或箭头函数。

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

props

每个组件对象都会有 props 属性,组件标签的所有属性都保存在 props 中。其基本使用如下:

<script type="text/babel">
  // 创建组件
  class Person extends React.Component {
    render(){
      const {name,age,gender} = this.props
      return (
        <ul>
          <li>姓名: {name}</li>
          <li>年龄: {age}</li>
          <li>性别: {gender}</li>
        </ul>
      )
    }
  }
  // 渲染页面到组件
  ReactDOM.render(<Person name="张三" age="18" gender="男" />,document.getElementById('root'))
</script>

如果想批量传递props,可以通过以下方式:

构造器是否接受props,是否传递给super,取决于:是否希望在构造器中通过this访问props。

函数式组件使用props

<script type="text/babel">
  // 函数式组件使用props
  function Person(props){
    const {name,age,gender} = props
    return (
        <ul>
          <li>姓名: {name}</li>
          <li>年龄: {age}</li>
          <li>性别: {gender}</li>
        </ul>
    )
  }
  // 渲染页面到组件
  ReactDOM.render(<Person name="张三" age="18" gender="男"/>,document.getElementById('root'))
</script>

注意

1)通过标签属性从组件外向组件内传递变化的数据

2)props是只读的,组件内部不要修改props

refs

组件内的标签可以定义ref属性来标识自己

字符串形式的ref

<script type="text/babel">
  // 创建组件
  class Demo extends React.Component {
    // 展示输入框左侧的数据
    showData = ()=>{
      const {input1} = this.refs
      alert(input1.value)
    }
    // 展示输入框右侧的数据
    showData2 = ()=>{
      const {input2} = this.refs
      alert(input2.value)
    }
    render(){
      return (
        <div>
          <input ref="input1" type="text" placeholder="点击按钮显示数据" />&nbsp;  
          <button onClick={this.showData}>点我显示数据</button>&nbsp;
          <input ref="input2" onBlur={this.showData2} type="text" placeholder="失去焦点提示数据" />
        </div>
      )
    }
  }
  // 渲染组件
  ReactDOM.render(<Demo/>,document.getElementById('root'))
</script>

虽然这种方式很简单,但是存在一定的效率问题,官方文档明确说明不建议去使用它:

回调形式的ref

拿到当前ref所在的节点,react帮助我们调用函数然后传进来,之后挂载到实例自身上。

<script type="text/babel">
  // 创建组件
  class Demo extends React.Component {
    // 展示输入框左侧的数据
    showData = ()=>{
      const {input1} = this
      alert(input1.value)
    }
    // 展示输入框右侧的数据
    showData2 = ()=>{
      const {input2} = this
      alert(input2.value)
    }
    render(){
      return (
        <div>
          <input ref={c => this.input1 = c} type="text" placeholder="点击按钮显示数据" />&nbsp;  
          <button onClick={this.showData}>点我显示数据</button>&nbsp;
          <input ref={c => this.input2 = c} onBlur={this.showData2} type="text" placeholder="失去焦点提示数据" />
        </div>
      )
    }
  }
  // 渲染组件
  ReactDOM.render(<Demo/>,document.getElementById('root'))
</script>

使用回调形式的ref会出现以下问题,如果想解决这个问题,可以用以下方式:

<script type="text/babel">
  // 创建组件
  class Demo extends React.Component {
    // 展示输入框的数据
    showData = ()=>{
      const {input1} = this
      alert(input1.value)
    }
    saveInput = (c)=>{
      this.input1 = c
      console.log('@');
    }
    render(){
      return (
        <div>
          {/*在JSX语法中,注释的书写方式是外层包裹大括号,表明里面是JS语法,写上注释即可表明当前为注释*/}
          <input ref={this.saveInput} type="text" placeholder="点击按钮显示数据" />&nbsp; 
          <button onClick={this.showData}>点我显示数据</button>&nbsp;
        </div>
      )
    }
  }
  // 渲染组件
  ReactDOM.render(<Demo/>,document.getElementById('root'))
</script>

createRef的使用

React.createRef调用后可以返回一个容器,该容器可以存储被ref所标识的节点。但这种形式有一种缺点就是只能容纳一个元素进行使用,如果想出里多个元素需创建多个createRef容器。

<script type="text/babel">
  // 创建组件
  class Demo extends React.Component {
    // 创建容器
    myRef = React.createRef()
    myRef1 = React.createRef()
    // 展示输入框的数据
    showData = ()=>{
      console.log(this.myRef.current);
      alert(this.myRef.current.value)
    }
    showData1 = ()=>{
      console.log(this.myRef1.current);
    }
    render(){
      return (
        <div>
          {/*在JSX语法中,注释的书写方式是外层包裹大括号,表明里面是JS语法,写上注释即可表明当前为注释*/}
          <input ref={this.myRef} type="text" placeholder="点击按钮显示数据" />&nbsp; 
          <button onClick={this.showData}>点我显示数据</button>&nbsp;
          <input type="text" onBlur={this.showData1} ref={this.myRef1} placeholder="另一个input" />
        </div>
      )
    }
  }
  // 渲染组件
  ReactDOM.render(<Demo/>,document.getElementById('root'))
</script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/164427.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ASP.NET Core 3.1系列(29)——System.Text.Json实现JSON的序列化和反序列化

1、前言 在Web开发中&#xff0c;JSON数据可以说是无处不在。由于具有轻量、易读等优点&#xff0c;JSON已经成为当前主流的数据传输格式。在ASP.NET Core 3.0之前&#xff0c;大多数项目都会使用Newtonsoft.Json组件来实现JSON的序列化和反序列化操作&#xff0c;而从ASP.NET…

《王道》操作系统整理

操作系统第1章 OS概述第1节 OS基本概念第2节 OS发展与分类第3节 OS运行机制和体系结构1.3.1 操作系统的运行机制1. 时钟管理2. 中断机制3. 原语4. 系统资源管理或系统控制的数据结构及处理1.3.2 中断和异常1.3.3 系统调用第2章 进程管理第3章 内存管理第4章 文件管理第5章 IO管…

【8】SCI易中期刊推荐——计算机 | 人工智能(中科院4区)

🚀🚀🚀NEW!!!SCI易中期刊推荐栏目来啦 ~ 📚🍀 SCI即《科学引文索引》(Science Citation Index, SCI),是1961年由美国科学信息研究所(Institute for Scientific Information, ISI)创办的文献检索工具,创始人是美国著名情报专家尤金加菲尔德(Eugene Garfield…

【SpringCloud11】Hystrix断路器

Hystrix断路器1.概述1.1分布式系统面临的问题1.2Hystrix 是什么1.3Hystrix 的作用1.4官网资料1.5Hystrix官宣停更进维2.Hystrix重要概念2.1服务降级&#xff08;fallback&#xff09;2.2服务熔断&#xff08;break&#xff09;2.3服务限流&#xff08;flowlimit&#xff09;3.H…

手把手教你使用Python实现推箱子小游戏(附完整源码)

文章目录项目介绍项目规则项目接口文档项目实现过程前置方法编写move核心方法编写项目收尾项目完善项目整体源码项目缺陷分析项目收获与反思项目介绍 我们这个项目是一个基于Python实现的推箱子小游戏&#xff0c;名叫Sokoban&#xff1a; 这个游戏的目的是让玩家&#xff0…

jfow-代码分析

jfow-代码分析目录概述需求&#xff1a;设计思路实现思路分析1.代码&#xff1a;2.代码2&#xff1a;3.CashFrmTemplate4.chartType5.DataColumnData:参考资料和推荐阅读Survive by day and develop by night. talk for import biz , show your perfect code,full busy&#xf…

Vue实战第1章:学习和使用vue-router

学习和使用vue-router 前言 本篇在讲什么 简单讲解关于vue-router的使用 仅介绍简单的应用&#xff0c;仅供参考 本篇适合什么 适合初学Vue的小白 适合想要自己搭建网站的新手 适合没有接触过vue-router的前端程序 本篇需要什么 对Html和css语法有简单认知 对Vue有…

2023/1/14 js基础学习

1 js基础学习-基本数据类型基本语法 请参考 https://blog.csdn.net/m0_48964052?typeblog https://gitee.com/hongjilin/hongs-study-notes/blob/master/%E7%BC%96%E7%A8%8B_%E5%89%8D%E7%AB%AF%E5%BC%80%E5%8F%91%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0/HTMLCSSJS%E5%9F%BA%E…

Arthas 入门到实战(二)在线热更新

1. 结合 jad/mc 命令在线修改使用 jad 命令: 将 JVM 中实际运行的 class 的 byte code 反编译成 java 代码&#xff0c;便于你理解业务逻辑&#xff1b; mc命令&#xff1a;Memory Compiler/内存编译器&#xff0c;编译.java文件生成.class。 redefine命令&#xff1a;加载…

unix进程控制及进程环境--自APUE

文章目录概述1、孤儿进程和僵尸进程进程终止进程的编译和启动进程终止的步骤进程8种终止方式进程退出函数1&#xff1a;exit进程退出函数2&#xff1a;_exit进程退出函数3&#xff1a;_Exit注册终止处理程序&#xff1a;atexit环境变量通过main函数传参全局的环境变量表&#x…

uni-app跨端自定义指令实现按钮权限

前言 初看这个标题可能很迷&#xff0c;uni-app明明不支持自定义指令&#xff0c;这文章是在搞笑吗&#xff0c;本文对于uni-app自定义指令实现按钮权限的方式也有可能是多余&#xff0c;但为了给业务部门更友好的开发体验&#xff0c;还是做了一些可能没意义的操作&#xff0…

回顾2022,展望 2023

个人相关&#xff1a; PMP 因为疫情多次延期的PMP终于搞定&#xff0c;光环的PMP就是妥妥。基本只要认真做题和思考都会过。但是考试不仅仅是考试&#xff0c;有时候更多的是对项目发展和项目管理的思考&#xff1a;风险&#xff0c;里程碑&#xff0c;相关方&#xff0c;敏捷&…

红日内网渗透靶场2

目录 环境搭建&#xff1a; Web渗透&#xff1a; weblogic漏洞利用 java反序列化漏洞利用、哥斯拉获取shell 上线msf msf派生shell到cs 内网信息收集 mimikatz获取用户密码 cs横向移动 PTT攻击&#xff08;票据传递&#xff09; 方法2&#xff1a;通过msf利用永恒之蓝…

测试之分类【测试对象、是否查看代码、开发】

文章目录1. 按测试对象分类2. 按照是否查看代码划分3. 按照开发阶段划分1. 按测试对象分类 可靠性测试容错性测试安装卸载测试内存泄露测试弱网测试 &#xff08;1&#xff09;可靠性测试 可靠性 正常运行时间 / (正常运行时间 非正常运行时间) * 100% &#xff08;最高 10…

Servlet的实战用法(表白墙前后端)

作者&#xff1a;~小明学编程 文章专栏&#xff1a;JavaEE 格言&#xff1a;热爱编程的&#xff0c;终将被编程所厚爱。 目录 服务器版本的表白墙 创建项目 约定前后端交互接口 获取全部留言 发表新的留言 服务端代码 创建Message类 创建DBUtil类 创建MessageServlet…

双指针合集

87合并两个有序的数组 import java.util.*; public class Solution {public void merge(int A[], int m, int B[], int n) { int i m-1;int j n-1;for(int k nm-1;k>0;k--){if(j<0) A[k] A[i--];else if(i<0) A[k] B[j--];else if(A[i]>B[j]) A[k] A[i--]…

六道数据结构算法题详解

目录 1.力扣350题. 两个数组的交集 II 2.力扣121题. 买卖股票的最佳时机 3.力扣566题. 重塑矩阵 4.力扣118题. 杨辉三角 5.牛客BM13 判断一个链表是否为回文结构 6.牛客BM14 链表的奇偶重排 1.力扣350题. 两个数组的交集 II 题目&#xff1a;给你两个整数数组 nums1 和 n…

2022年终总结---权衡好工作和生活

2022总结 【校园】2022年6月研究生顺利毕业&#xff0c;让下文的一切才变的有机会。感谢师弟送学长毕业&#xff0c;感谢在最后时刻各位舍友帮忙送材料&#xff0c;怀念最后一个月一起打球的时光。 【工作】2022年6月入职阿里&#xff0c;成为打工人。在这个大的平台&#xf…

Goland项目使用gomod配置

Goland 项目创建 goland2020.3 及以上 IDE&#xff0c;默认创建的 go 项目 就是使用 gomod 管理&#xff01; goland2020.3 及以下的 IDE&#xff0c;创建项目时需要选择 带小括号 vgo 的才是 gomod 管理模式 下图为使用 goland2021.3 版本创建使用 gomod 管理的 go 项目&…

14种可用于时间序列预测的损失函数

在处理时间序列预测问任务时&#xff0c;损失函数的选择非常重要&#xff0c;因为它会驱动算法的学习过程。以往的工作提出了不同的损失函数&#xff0c;以解决数据存在偏差、需要长期预测、存在多重共线性特征等问题。本文工作总结了常用的的 14 个损失函数并对它们的优缺点进…