美文网首页
javascript this变量

javascript this变量

作者: zzzabc | 来源:发表于2016-10-26 17:17 被阅读37次

最近在练习react native,碰到一个坑。程序一直报this.setState is not a function

import React, { Component } from 'react';
import { AppRegistry, ListView, Text, View } from 'react-native';

class ListViewBasics extends Component {
    // 初始化模拟数据
    constructor(props) {
        super(props);
        const ds = new ListView.DataSource({rowHasChanged: (r1, r2) => r1 !== r2});
        this.state = {
            dataSource: ds.cloneWithRows([
                'John', 'Joel', 'James', 'Jimmy', 'Jackson', 'Jillian', 'Julie', 'Devin'
            ]),
            test: 'test'
        };
        // 少了这一行,就会报错
        this._onPress.bind(this);
    }

    _onPress() {
        this.setState({test: '11111'});
    }

    render() {
        return (
            <View style={{paddingTop: 22}}>
                <ListView
                    dataSource={this.state.dataSource}
                    renderRow={(rowData) => <Text onPress={this._onPress}>{rowData}</Text>}
                />
            </View>
        );
    }
}

// 注册应用(registerComponent)后才能正确渲染
// 注意:只把应用作为一个整体注册一次,而不是每个组件/模块都注册
AppRegistry.registerComponent('test', () => ListViewBasics);

主要原因是没有调用bind函数,其实在示例代码也看到过需要调用this._onPress.bind(this),只是不理解原因,所以印象不深刻,自己再敲一遍就忘了。

翻了下this相关的资料
JavaScript 中的作用域 scope 和上下文 context 是这门语言的独到之处,每个函数有不同的变量上下文和作用域。这些概念是 JavaScript 中一些强大的设计模式的后盾。在ES5规范里,我们可以遵循一个原则——每个 function 内的上下文 this 指向该 function 的调用方。

var Module = {
    name: 'Jafeney',
    first: function() {
        console.log(this);   // this对象指向调用该方法的Module对象
        var second = (function() {
            console.log(this)  // 由于变量提升,this对象指向Window对象
        })()
    },
    init: function() {
        this.first()
    }
}

Module.init()

类似的还有这样的(截图原自《Javascript高级程序设计》):

Javascript高级程序设计.png

回到上面最开始的那个React例子在render函数里面

  <Text onPress={this._onPress}>{rowData}</Text>}

相当于

   var onpress = this._onPress;
   // 在onclick的时候,调用
   onpress();   // this指向其他环境,而不是之前的类对象

至于 this._onPress = this._onPress.bind(this); 其实等价于:

    //  相当于用了类原型生成了一个bind到当前对象的函数
    //  再覆盖当前函数,来保证这个函数的this永远不会被改变
    this._onPress = this.protoType._onPress.bind(this);
    var onpress = this._onPress;
    // 组件被click的时候
   onpress();  //即使在全局环境调用,this也不会被改变

至于箭头操作符,作用域的规则不一样,具体可以看资料的链接。
好多不懂的,继续学习吧。

参考资料

深入理解React中的上下文this
ECMAScript 6 入门 class

相关文章

  • JS的基本语法--变量及类型

    1. 基本语法 声明(创建) JavaScript 变量在 JavaScript 中创建变量通常称为“声明”变量。...

  • 7 js 变量

    13 局部 JavaScript 变量在 JavaScript 函数内部声明的变量(使用 var)是局部变量,所以...

  • Javascript 变量、函数的声明

    javascript变量 全局变量和局部变量按照变量的作用域来区分,和大多数编程语言类似,javascript变量...

  • JavaScript 变量作用域和内存问题

    按照ECMAScript的定义,JavaScript的变量与其他语言的变量有很大区别。JavaScript变量松散...

  • javascript学习思维导图

    JavaScript 数据类型 JavaScript 变量 Javascript 运算符 JavaScript 流...

  • JavaScript函数闭包

    JavaScript闭包 JavaScript 变量可以是局部变量或全局变量。私有变量可以用到闭包。 全局变量1....

  • js语法难点

    javascript语法难点问题 Javascript的变量javascript语言和java语言一样变量是分为两...

  • js归纳总结——各种思维导图

    javascript DOM操作 javascript windows对象 javascript变量 javasc...

  • js语法

    JavaScript 变量 在编程语言中,变量用于存储数据值。 JavaScript 使用关键字var来定义变量,...

  • 变量

    JavaScript 变量JavaScript 变量是存储数据值的容器。 在本例中,x、y 和 z 是变量: 实例...

网友评论

      本文标题:javascript this变量

      本文链接:https://www.haomeiwen.com/subject/phmduttx.html