react中super()的理解

49 篇文章 0 订阅
34 篇文章 0 订阅

es6 class(类) 方法创建组件

1 // 构造函数 会 默认生成 一个原型对象
2 function Person(name,) {
3        this.name = name;
4      }
5      console.log(Person);                          // 构造函数本身
6      console.log(Person.prototype)               // 指向原型对象
7      console.log(Person.prototype.constructor);    // 指向 构造函数本身
8      Person("范顺");

复制代码

在class(类) 方法中,同理可得 constructor(props),

子类继承父类的属性:需要使用super()继续父类的属性,同时创建this(子类本身没有this);

所以super(props)的作用就是在父类的构造函数中给props赋值一个对象this.props=props这样就能在它的下面定义你要用到的属性了,然而其他的由于没有传参就直接赋值为undefind

复制代码

class Hello extends React.Component {
  constructor(props) {
    super(props)         // 子类继承父类,this
    console.log(props)
  }
  render() {
    return null;
  }
}

复制代码

拓展部分:理解 super( ) ——继承

在class方法中,继承是使用 extends 关键字来实现的

复制代码

 1     class People{
 2         constructor(name,age){
 3             this.name = name;
 4             this.age = age;
 5         }
 6         sayName(){
 7             return '我的名字是:'+this.name;
 8         }
 9     }
10 
11     class har extends People{
12         constructor(name,age,sex){
13             super(name,age);//调用父类的constructor(name,age)
14             this.sex = sex;
15         }
16         haha(){
17             return this.sex + ' ' + super.sayName();//调用父类的sayName() 
18         }
19     }

复制代码

上面的例子中,出现了 super( ),子类 必须 在 constructor( )调用 super( )方法,否则新建实例时会报错。(不要问为什么!)

报错的原因是:子类是没有自己的 this 对象的,它只能继承自父类的 this 对象,然后对其进行加工,而super( )就是将父类中的this对象继承给子类的。没有 super,子类就得不到 this 对象,没有 this 对象而要对 this 进行处理,能不报错吗?

复制代码

1     class Ha{/*某些代码*/}
2 
3     class haha extends Ha{
4         constructor(){}
5     }
6 
7     let haha1 = new haha();ReferenceError报错

复制代码

出现上面情况的总原因是,ES5的继承机制与ES6完全不同。

复习一个重要知识点——ES5中new到底做了些啥?
当一个构造函数前加上new的时候,背地里来做了四件事:
1.生成一个空的对象并将其作为 this;
2.将空对象的 __proto__ 指向构造函数的 prototype
3.运行该构造函数;
4.如果构造函数没有 return 或者 return 一个返回 this 值是基本类型,则返回this;如果 return 一个引用类型,则返回这个引用类型。

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
React的受控组件和非受控组件是两种处理表单数据的方式。 受控组件是指由React来管理表单元素的状态和值。在受控组件,表单元素的值由React的状态(state)来控制,当用户输入数据时,React会更新状态并重新渲染组件。通过使用onChange事件处理函数,可以监听表单元素的变化并更新状态。 例如,一个受控的文本输入框可以这样定义: ```jsx class ControlledInput extends React.Component { constructor(props) { super(props); this.state = { value: '' }; } handleChange(event) { this.setState({ value: event.target.value }); } render() { return ( <input type="text" value={this.state.value} onChange={this.handleChange.bind(this)} /> ); } } ``` 在上面的例子,文本输入框的值由React的状态value控制,当用户输入时,handleChange函数会更新状态value并重新渲染组件。 相反,非受控组件是指由DOM本身来管理表单元素的状态和值。在非受控组件,表单元素的值由DOM直接处理,React不控制其状态。我们可以通过ref来获取表单元素的值。 以下是一个非受控文本输入框的示例: ```jsx class UncontrolledInput extends React.Component { constructor(props) { super(props); this.inputRef = React.createRef(); } handleSubmit(event) { event.preventDefault(); console.log('Input Value:', this.inputRef.current.value); } render() { return ( <form onSubmit={this.handleSubmit.bind(this)}> <input type="text" ref={this.inputRef} /> <button type="submit">Submit</button> </form> ); } } ``` 在上面的例子,我们使用了ref来获取文本输入框的值,并在表单提交时打印出输入的值。 总而言之,受控组件适用于需要对表单数据进行精确控制和验证的场景,而非受控组件适用于简单的表单操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值