阮一峰的网络日志有感

Posted myfirstboke

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了阮一峰的网络日志有感相关的知识,希望对你有一定的参考价值。

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.

以上是关于阮一峰的网络日志有感的主要内容,如果未能解决你的问题,请参考以下文章

理解OAuth 2.0 - 阮一峰的网络日志

阮一峰网络日志 第82期

Flex 布局教程:语法篇(转自阮一峰的网络日志)

React 入门实例教程[阮一峰的网络日志] (分享)

阮一峰网络日志 第38期 2019年01月04日

阮一峰网络日志 第37期 2018年12月28日