react 类组件函数中拿不到state问题

1使用箭头函数 ,this指向向上指就拿到了

2:使用bind,改变this指向

import Lottie from 'lottie-web'
import React from "react";
import * as Menu from './json/menu.json'
export default class MenuLottie extends React.Component {
  constructor(props: NonNullable<unknown>) {
    super(props)
    this.state = {
      menuL:null
    }
  }
  componentDidMount() {
   const menuL = Lottie.loadAnimation({
      container: document.getElementById('menu-lottie') as Element,
      renderer: 'svg',
      loop: false,
      autoplay: false,
      animationData:Menu
    })
    this.setState({
      menuL:menuL
    })
  }
  // 写法1
  // openMenu(){
  //   console.log(this.state,24)
  // }
  // 写法2
  openMenu = () =>{
    console.log(this.state,24)
  }
  render() {
      // 写法1
      // return <div id="menu-lottie" onClick={this.openMenu.bind(this)}/>
      // 写法2
      return <div id="menu-lottie" onClick={this.openMenu}/>
  }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值