zoukankan      html  css  js  c++  java
  • 几句话就能让你理解:this、闭包、原型链

    以下是个人对这三个老大难的总结(最近一直在学习原生JS,翻了不少书,不少文档,虽然还是新手,但我会继续坚持走我自己的路)

    原型链

    所有对象都是基于Object.prototypeObject.prototype就是JavaScript的根对象,在Object.prototype中定义的方法都可以被其它对象访问到,当然也可以被重写了,所以直接在Object.prototype上调用的是原始功能的toString()方法,该方法会放回参数对象的内置属性[[class]]的值,这个值是个字符串,比如'[Object String]'

    要理解原型链机制的话,首先得知道根本原因:JavaScript中的对象都有一个内置属性[[Prototype]],这个属性和非标准的__proto__属性一样,__proto__在ES6中被纳入标准了,可以说它们基本上是等价的,但内置属性是无法访问到的。对象之间通过内置属性[[Prototype]]关联了起来就形成了原型链,而原型链的顶层就是根对象Object.prototypeObject.prototype的原型将是null,即Object.prototype.__proto__ === null;

    例如:
    在访问对象的属性的时候,如:obj.a,首先查找自身,没有,就到它的内置属性[[Prototype]]所引用的对象上找,还是没有,就继续在这个上层对象的内置属性[[Prototype]]所引用的对象上找,一直找到根对象Object.prototype,找不到就返回undefined;

    this

    理解this的第一步就是要明白:this既不指向函数自身,也不指向函数的词法作用域;
    this是在运行时进行绑定的,而不是在编写时绑定,它的上下文取决于函数调用时的各种条件;
    this的绑定和函数声明的位置没有任何关系,只取决于函数的调用位置和调用方式;
    this绑定规则有4点:按优先级1到4判断

    1. 由new调用?绑定到新创建的空对象;
    2. call、apply、bind调用?绑定到指定的参数对象;如foo.call(obj)
    3. 由上下文对象调用?绑定到这个上下文对象;如obj.foo()
    4. 默认情况下绑定到全局对象,foo();在严格模式下绑定到undefined

    闭包

    function foo(){
            var a = 2;
            function bar(){}
            return bar;
    }
    var a = foo();
    a(); 
    

    闭包:不是指函数bar也不是a,它是一个引用,这个引用被内部函数bar持有,这个引用指向外部函数foo的整个作用域,它使得这个作用域即使在外部函数foo()执行后也不会被垃圾回收器回收。也就是说这个外部函数foo的作用域就是闭包本身。
    无论通过何种手段(直接或间接)将内部函数传递到所在的词法作用域以外,它都会持有对原始定义作用域的引用,无论在何处执行这个函数都会使用闭包。

    var fn;  //间接传递函数
    function foo(){
            var a = 2;
            function baz(){
                console.log(a);
            }
            fn = baz;
    }
    function bar(){ fn();}
    foo();
    bar();
    
    function foo(){
            var a = 2;
            function  baz(){
                console.log(a);
            }
            bar(baz);
    }
    function bar(fn){ fn(); }
    
  • 相关阅读:
    [nodejs]npm国内npm安装nodejs modules终极解决方案
    [nodejs]解决mysql和连接池(pool)自动断开问题
    [nodejs]国内npm安装nodejs modules失败的几个解决方案
    [less]用webstorm自动编译less产出css和sourcemap
    [javascript] Promise API
    [javascript]巧用sourcemap快速定位javascript中的问题
    Gruntjs提高生产力(四)
    Gruntjs提高生产力(三)
    Gruntjs提高生产力(二)
    Gruntjs提高生产力(一)
  • 原文地址:https://www.cnblogs.com/susufufu/p/5906467.html
Copyright © 2011-2022 走看看