2016.06.14廖雪峰JS__学习笔记(函数部分)__P4

来源:互联网 发布:淘宝网天猫女童装裙子 编辑:程序博客网 时间:2024/06/05 03:14

1

闭包

返回闭包时牢记的一点就是:返回函数不要引用任何循环变量,或者后续会发生变化的变量。

在面向对象的程序设计语言里,比如Java和C++,要在对象内部封装一个私有变量,可以用private修饰一个成员变量。

在没有class机制,只有函数的语言里,借助闭包,同样可以封装一个私有变量。

闭包就是携带状态的函数,并且它的状态可以完全对外隐藏起来。

2

Arrow Function(箭头函数)

x => x * x

上面的箭头函数相当于:

function (x) {    return x * x;}


如果要返回一个对象,就要注意,如果是单表达式,这么写的话会报错:

// SyntaxError:x => { foo: x }

因为和函数体的{ ... }有语法冲突,所以要改为:

// ok:x => ({ foo: x })

3

箭头函数和匿名函数有个明显的区别:箭头函数内部的this是词法作用域,由上下文确定。

下面的例子无法得到预期结果:

var obj = {    birth: 1990,    getAge: function () {        var b = this.birth; // 1990        var fn = function () {            return new Date().getFullYear() - this.birth; // this指向window或undefined        };        return fn();    }};

现在,箭头函数完全修复了this的指向,this总是指向词法作用域,也就是外层调用者obj

var obj = {    birth: 1990,    getAge: function () {        var b = this.birth; // 1990        var fn = () => new Date().getFullYear() - this.birth; // this指向obj对象        return fn();    }};obj.getAge(); // 25

如果使用箭头函数,以前的那种hack写法:

var that = this;

就不再需要了。







0 0
原创粉丝点击