React 组件之props属性的使用

 更新时间:2025年09月16日 08:13:23   作者:来一碗刘肉面  
在React中,props是组件之间传递数据的一种方式,它是 React 组件的基础,用于将数据从父组件传递到子组件,本文就来详细的介绍一下,感兴趣的可以了解一下

在 React 中,props(即属性)是组件之间传递数据的一种方式。它是 React 组件的基础,用于将数据从父组件传递到子组件。

一、类组件中

1.props的作用

  • 数据传递props 允许父组件向子组件传递数据。子组件可以使用这些数据来渲染内容、改变显示的内容等。
  • 控制组件行为: 通过 props,父组件可以控制子组件的行为和外观。这些属性可以是基本数据类型、函数、数组等。
  • 组件间的通信props 是父子组件通信的重要机制。子组件不能直接修改父组件的状态,但可以通过 props 收到函数作为属性,进而通知父组件去更新状态。

2. 基本语法

传递props

父组件可以向子组件传递 props,使用自定义标签时就像设置 HTML 属性一样:

// 父组件
class ParentComponent extends React.Component {
    render() {
        return (
            <ChildComponent name="Alice" age={10} />
        );
    }
}

 在上面的例子中,父组件 ParentComponent 向子组件 ChildComponent 传递了两个属性:name 和 age。

接收props

子组件通过 this.props 访问传递给它的 props,可以在 render() 方法或其他生命周期方法中使用:

// 子组件
class ChildComponent extends React.Component {
    render() {
        return (
            <div>
                <p>Name: {this.props.name}</p>
                <p>Age: {this.props.age}</p>
            </div>
        );
    }
}

3.props的特点

  • 不可变性: props 是只读的,子组件不能直接修改从父组件传递来的 props。如果需要更新状态,应该通过回调函数通知父组件由父组件来更改状态。
  • 动态更新: 当父组件的状态发生变化时,React 会重新渲染子组件,并更新 props 中的值。
// 父组件
class ParentComponent extends React.Component {
    constructor(props) {
        super(props);
        this.state = {
            name: "Alice",
            age: 10
        };
    }

    incrementAge = () => {
        this.setState(prevState => ({ age: prevState.age + 1 }));
    };

    render() {
        return (
            <div>
                <ChildComponent 
                    name={this.state.name} 
                    age={this.state.age} 
                    incrementAge={this.incrementAge} 
                />
            </div>
        );
    }
}

// 子组件
class ChildComponent extends React.Component {
    render() {
        return (
            <div>
                <h1>Name: {this.props.name}</h1>
                <h2>Age: {this.props.age}</h2>
                <button onClick={this.props.incrementAge}>Increment Age</button>
            </div>
        );
    }
}

// 渲染组件
ReactDOM.render(<ParentComponent />, document.getElementById('root'));

4. 组件的propTypes和默认props

 import PropTypes from 'prop-types';

// 定义属性类型
    Person.propTypes = {
        name: PropTypes.string.isRequired, // 必传,字符串
        age: PropTypes.number.isRequired,   // 必传,数字
        sex: PropTypes.string                // 可选,字符串
        speak:PropTypes.func                 // 可选,函数
    };
    // 定义默认属性(可选)
    Person.defaultProps = {
        sex: '未知' // 如果未传性别,默认是 '未知'
    };
// 定义规则
    // Sum.属性规则 = {
    //     name:'必传,字符串'
    // }
    // 定义属性类型
    static propTypes = {
        name: PropTypes.string.isRequired, // 必传,字符串
        age: PropTypes.number.isRequired,   // 必传,数字
        sex: PropTypes.string                // 可选,字符串
    };
    // 定义默认属性(可选)
    static defaultProps = {
        sex: '未知' // 如果未传性别,默认是 '未知'
    };

// 可以这样访问
console.log(Person.propTypes); // 访问类中的静态 propTypes
console.log(Person.defaultProps); // 访问类中的静态 defaultProps

// 而不能这样访问

const instance = new Person();
console.log(instance.propTypes); // 这会返回 undefined,因为 propTypes 是静态的

使用 static 关键字的主要目的是将某些属性或方法与类本身关联,而不是与任何实例相关。在 React 组件中,这通常用于定义 propTypes 和 defaultProps,确保这些配置在类的上下文中清晰可见,并且可以通过类来直接访问。

二、函数组件中

函数式组件中三大属性只有Props属性可以使用

与类组件不同,函数组件没有实例,直接接受 props 作为参数。

import React from 'react';

const MyComponent = (props) => {
    // const {title,content} = props
    return (
        <div>
            <h1>{props.title}</h1>
            <p>{props.content}</p>
        </div>
    );
};

// 或
//const MyComponent = ({ name, age }) => {
//    return (
//        <div>
//           <p>名称: {name}</p>
//            <p>年龄: {age}</p>
//        </div>
//    );
//};

// 默认属性
MyComponent.defaultProps = {
    name: '匿名',
    age: 0,
};

到此这篇关于React 组件之props属性的文章就介绍到这了,更多相关React props属性内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • react中的axios模块你了解吗

    react中的axios模块你了解吗

    这篇文章主要为大家详细介绍了react中的axios模块,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03
  • React应用中避免白屏现象的方法小结

    React应用中避免白屏现象的方法小结

    在开发React应用程序时,我们都曾遇到过这样的场景:一个未被捕获的异常突然中断了组件的渲染流程,导致用户界面呈现出一片空白,也就是俗称的“白屏”现象,本文将探讨如何在React应用中有效捕获并处理这些错误,避免白屏现象的发生,需要的朋友可以参考下
    2024-06-06
  • 记一个React.memo引起的bug

    记一个React.memo引起的bug

    memo可以自己决定是否更新,但它是一个函数组件而非一个类,本文主要介绍了React.memo引起的bug,具有一定的参考价值,感兴趣的可以了解一下
    2022-03-03
  • 详解React项目的服务端渲染改造(koa2+webpack3.11)

    详解React项目的服务端渲染改造(koa2+webpack3.11)

    本篇文章主要介绍了详解React项目的服务端渲染改造(koa2+webpack3.11),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03
  • React + Node.js实现图片上传功能

    React + Node.js实现图片上传功能

    最近笔者在开发个人博客的后台管理系统,里面用到了图片上传相关的功能,在这里记录并分享一下,希望可以帮到大家,话不多说直接开始吧,感兴趣的朋友可以参考下
    2024-01-01
  • React中如何实现受控组件与非受控组件

    React中如何实现受控组件与非受控组件

    在 React 开发里,组件可分为受控组件和非受控组件,这篇文章将为大家介绍一下它们的实现原理,方法,区别,作用和应用场景是什么,希望对大家有所帮助
    2025-03-03
  • react hooks中的useState使用要点

    react hooks中的useState使用要点

    这篇文章主要为大家介绍了react hooks中的useState使用要点详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • 利用React-router+Webpack快速构建react程序

    利用React-router+Webpack快速构建react程序

    目前 React、Webpack 等技术如火如荼,你是不是还在愁苦如何把这些杂乱的知识怎么学习一下,开启一段新的前端开发之路呢?那么这篇将给大家运用示例代码详细的介绍使用React-router和Webpack如何快速构建一个react程序,感兴趣的朋友们下面来一起看看吧。
    2016-10-10
  • react-native只保留3x图原理解析

    react-native只保留3x图原理解析

    这篇文章主要为大家介绍了react-native只保留3x图原理解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01
  • 详解React 和 Redux的关系

    详解React 和 Redux的关系

    这篇文章主要为大家介绍了React 和 Redux的关系,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2021-11-11

最新评论