标签:btn 返回 def ret css click 组件 input 技术
1.App.js的代码如下:
import React, { Component } from ‘react‘; import Test from ‘./components/Test.jsx‘; import ‘./assets/css/todolist.css‘; class App extends Component { //组件的构造函数,当这个组件被执行的时候,constructor会自动被执行 constructor(props){ //固定的写法 super(props); this.state = { list: [ ‘learn react‘, ‘learn english‘, ‘learn vue‘ ] } } handleBtnClick() { this.state.list.push(‘hello world‘); } render() { return ( <div> <div> <Test/> </div> <div className="todoListStyle"> <div> <input /> <button onClick={this.handleBtnClick}>Add</button> </div> <ul> { this.state.list.map((item) => { return <li>{item}</li> }) } </ul> </div> </div> ); } } export default App;
运行项目,控制台中报错:
分析:handleBtnClick这个函数执行的时候,函数体里面的this指的是button这个按钮,这个按钮上是没有state这个变量的,所以我们希望点击Add这个按钮的时候,handleBtnClick这个函数中的this指向的是当前这个组件
我们可以把代码改写成这样 onClick={this.handleBtnClick.bind(this)} 这句代码的意思是这个函数执行的时候,this永远都指向外面的这个this,外面的这个this指向的是当前这个组件
但是控制台中还会有另外一个错误:
分析:在react中,当要改变this.state中的数据,不要直接去调用this.state.list这样去改,需要调用react提供给我们的一个方法:setState
并且对于返回的每一个<li>标签,都需要有一个key
所以上面的代码应改写为:
标签:btn 返回 def ret css click 组件 input 技术
原文地址:https://www.cnblogs.com/fuhuirong/p/10320392.html