阮一峰的网络日志有感

http://www.ruanyifeng.com/blog/javascript/

1.闭包

我看过了之后的理解,闭包就是函数中的函数,为啥这么写呢,平时我们可以获取全局变量的值,现在我要获取函数里面的值,怎么获取呢,就是通过函数中在写一个函数(这个函数可以获取父函数的变量),然后return出去这个函数,就可以在外部拿到这个函数里面的变量了啊,闭包耗内存,在本质上,闭包就是将函数内部和函数外部连接起来的一座桥梁。

  var name = "The Window";

  var object = {
    name : "My Object",

    getNameFunc : function(){
      return function(){
        return this.name;
      };

    }

  };

  alert(object.getNameFunc()()); //The Window

  为啥是window 呢,因为

this对象是在运行时基于函数执行环境绑定的,在全局函数中,this=window,在函数被作为某个对象的方法调用时,this等于这个对象。

但是匿名函数的执行环境是全局性的,这里getNameFunc 方法return了一个匿名函数,这个匿名函数中this指向window

解决方法还是有的,我们可以把外部作用域的this传递给匿名函数

  var name = "The Window";

  var object = {
    name : "My Object",

    getNameFunc : function(){
      var that = this;
      return function(){
        return that.name;
      };

    }

  };

  alert(object.getNameFunc()());My Object

学到了匿名函数执行环境是全局性的指向window

2.js设计语言的糟粕

JavaScript 的 == 判断符隐含着各种隐式转换,对于这种设计上的坑,最好的避免方式就是不使用,没有必要为语言的糟粕买单。

==和!=会自动进行类型转换

‘true’ ==true -->false

参考规则https://www.cnblogs.com/wl521/p/7423852.html

这是设计js语言的锅,为了避免这个锅,以后写的项目全部用 === 和!== 类型和值都得相等

3.

猜你喜欢

转载自www.cnblogs.com/myfirstboke/p/11357159.html