栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

在哪里在React JS中声明变量

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

在哪里在React JS中声明变量

在React中使用ES6语法不会绑定

this
到用户定义的函数,但是会绑定
this
到组件生命周期方法。

因此,您声明的函数不会与该类具有相同的上下文,并且尝试访问该函数

this
不会给您期望的结果。

为了获得类的上下文,您必须将类的上下文绑定到该函数或使用箭头函数。

方法1绑定上下文:

class MyContainer extends Component {    constructor(props) {        super(props);        this.onMove = this.onMove.bind(this);        this.testVarible= "this is a test";    }    onMove() {        console.log(this.testVarible);    }}

方法2绑定上下文:

class MyContainer extends Component {    constructor(props) {        super(props);        this.testVarible= "this is a test";    }    onMove = () => {        console.log(this.testVarible);    }}

方法2是我的首选方法, 但是您可以自由选择自己的方法。

更新: 您也可以在没有构造函数的类上创建属性:

class MyContainer extends Component {    testVarible= "this is a test";    onMove = () => {        console.log(this.testVarible);    }}

注意 如果还想更新视图,则在设置或更改值时应使用

state
setState
方法。

例:

class MyContainer extends Component {    state = { testVarible: "this is a test" };    onMove = () => {        console.log(this.state.testVarible);        this.setState({ testVarible: "new value" });    }}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/636481.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号