前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >组件与props简解

组件与props简解

作者头像
柴小智
发布2020-01-15 17:12:13
5340
发布2020-01-15 17:12:13
举报
文章被收录于专栏:菜鸟计划菜鸟计划
一、创建组件
代码语言:javascript
复制
1.函数式创建

二、组件渲染

代码语言:javascript
复制
单闭合调用(只能传props的值)
<Title />

双闭合调用 (标签内还可以写子标签) 
<Title></Title>
三.属性

调取组件的时候,传递给组件的信息(render渲染的时候会把props传递给组件,props就是属性)

作用:让组件丰富化(传递不同的属性控制组件展示不同的效果)

特点:传递进来的属性在组件内部不能修改,也就是它是“只读的”。(修改属性的值,只能重新调取组件并且重新传递值)

虽然不可以修改属性值,但是在类创建组件的方式中,我们可以给组件设置默认值和设置一些规则。

代码语言:javascript
复制
import React from 'react';

import PropTypes from 'prop-types';  //使用 PropTypes 进行类型检查

class Say extends React.Component{
  //设置默认值
  static defaultProps = {
    title: 'hello word'
  }
  //设置默认规则
  static propTypes = {
    title: PropTypes.string,
    num: PropTypes.number.isRequired
  }
  constructor(props){
    //当super中没有传入props时
    /**
    * 1.在调用组件开始执行constructor,参数props是传递进来的属性信息(而且是经过defaultProps和propTypes等处理过的)
    * 2.但是此时还没有挂载到实例上,所以this.props的结果是undefined
    * 3.constructor结束后,挂载就完成了,所以其它生命周期函数中是可以基于this.props来获取属性的
    */
    // super();
    // console.log(props, this.props) //{title: "two", num: 20} undefined

    //当super中传入props时
    /**
    * 会在当前实例上挂载很多私有属性
    * this.props = props;
    * this.context = context;
    * this.refs = {};
    * 现在不这样处理,当constructor执行完成,react也会帮我们给实例挂载这些属性
    */
    super(props); //call继承:React.Component.call(this)
    console.log(props, this.props) //{title: "two", num: 20} {title: "two", num: 20}

    //实例上还可以调取Component类的两个方法
    /**
    * this.setState()
    * this.forceUpdate()
    */
  }
  render() {
    return (
      <p>{this.props.title}</p>
    )
  }
}
// Say.propTypes = {
// title: PropTypes.string
// }
export default Say;

<Say title={'two'} num={20}></Say>
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-01-08 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、创建组件
  • 三.属性
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档