词法作用域

  1. 作用域就是,程序查找变量和有效执行所在的区域,也称词法作用域。

  2. 词法作用域分为,静态作用域和动态作用域。

  3. 静态作用域取决于程序代码定义的时候,动态作用域取决于程序动态执行时的具体作用域环境。

  4. js采用静态作用域,对于变量对象的获取只基于定义环境,而不受执行变化的影响。

  5. 实例如下:

    var scope = "global scope";
    function checkscope(){
    var scope = "local scope";
    function f(){
    return scope;
    }
    return f;
    }
    checkscope()(); //结果为local scope

执行上下文栈

  1. js可执行代码类型分为3种:全局代码、函数代码、eval代码。
  2. 执行时,会进行代码分析,以一种执行栈的方式去执行代码,类似数组的入栈和出栈,以后进先出的方式完成代码执行
  3. 压栈和出栈的内容,被称之为执行上下文,又分为全局上下文和函数上下文。
  4. 压栈的时候,js引擎首先遇到的即是全局代码,也就是全局上下文,然后就是可执行的函数上下文。

执行上下文

  1. 全局代码和函数代码在被引擎分析时,都会形成一个入栈对象,称之为执行上下文。
  2. 可以将其抽象的理解为object,用来追踪关联代码的执行进度。
  3. 包含3个属性:变量对象,作用域链,this。
  4. 拥有2个状态:代码准备,代码执行。

变量对象

  1. 变量对象就是,与执行上下文相关的数据作用域,包含变量,形参和函数声明等。
  2. 因为存在全局上下文和函数上下文之分,所以在变量对象上存在区别。
  3. 在全局上下文中,变量对象就是宿主环境代表的window,初始化拥有规范内置的一系列属性,在进入全局上下文时,会给window添加变量和函数声明等初始值。
  4. 在函数上下文中,变量对象初始化时只拥arguments属性对应的Arguments对象,在进入函数上下文时,会给变量对象添加形参、函数声明、变量声明等初始值。
  5. 在代码准备阶段(进入上下文时),会给变量对象的属性赋入初始值;在代码执行阶段,会再次修改变量对象的属性值。
  6. 在全局上下文中,变量对象属性就称为VO(变量对象);在函数上下文中,变量对象属性就被称为AO(活动对象)

作用域链

  1. 当查找变量时,js会先从当前上下文的变量对象中查找,如果没有找到,就会从父级上下文的变量对象中查找,这样由多个执行上下文的变量对象构成的链表就叫做作用域链。
  2. 在js中,全局上下文属于一级链条,函数上下文开始为次级链条。
  3. 函数有一个作用域属性[[scope]],用于保存父变量对象,作为父变量对象的层级链存在,一级一级直至全局上下文的变量对象,因而构成作用域链。
  4. 函数创建时,函数的作用域属性[[scope]]也被创建,直至函数销毁前一直存在。
  5. 函数激活时(进入函数上下文时),创建AO(活动对象)后就会将其添加到作用链的前端,因此变量查找才会一级一级逐上。
  6. 通过Function函构造函数创建的函数的[[scope]]属性总是唯一的全局对象。

this

  1. 在一个上下文中,this由调用者提供,由调用的方式决定,因此this为何值只取决于调用时。

  2. 调用函数方式对this值的影响取决于规范里的抽象类型Reference(包含base value,referenced name和strict reference)。

  3. 在函数调用中,如果调用括号()的左边是引用类型(Reference type)的值,this将设为引用类型值的base对象(base object),在其他情况下(与引用类型不同的任何其它属性),这个值为null(第5版的ECMAScript中,已经不强迫转换成全局变量了,而是赋值为undefined)。

  4. 在分析this的时,这里的引用类型是指代的是程序内部运行的描述名称,具体可参考ECMAScript 5.1,或者这篇文章

  5. 实例如下:

    var value = 1;
    
    var foo = {
    value: 2,
    bar: function () {
    return this.value;
    }
    } //示例1
    console.log(foo.bar()); //2
    //示例2
    console.log((foo.bar)()); //2
    //示例3
    console.log((foo.bar = foo.bar)()); //1
    //示例4
    console.log((false || foo.bar)()); //1
    //示例5
    console.log((foo.bar, foo.bar)()); //1

闭包

  1. 在自身的作用域外被调用并使得作用域和活动对象被保存的现象,也就是内部作用域被外部作用域持有的情况。
  2. 从理论角度讲,所有的JavaScript函数都是闭包,因为它们都在创建的时候就将上层上下文的数据保存起来了。
  3. 从实践角度讲,一个函数执行时将内部函数引用返回给外部变量持有时就产生了闭包,返回的内部函数依然会持有执行函数的上下文。

原型与原型链

  1. 每一个函数都拥有一个prototype属性,每一个js对象都拥有一个__proto__属性
  2. prototype和__proto__的关系是,prototype属于对应js对象的__proto__所指
  3. 所有js函数(包括内置函数)的prototype都指向Object.prototype,所有函数作为对象,其__proto__都指向Function内置对象的prototype
  4. js内置函数中,只有Function内置函数的__proto__指向了自身的prototype,被自身创建
  5. js内置函数中,只有Object的prototype的__proto__为null,属于原型链的终点
  6. 每个prototype都有一个constructor属性指向关联的构造函数,每一个通过new进行初始化的函数实例的__proto__都指向函数的prototype
  7. js通过prototype和__proto__的关系实现了一个委托链条,__proto__一级接一级构成原型链

参数传递

  • 图示

  • 实例代码

  • 说明图

javascript核心基础总结的更多相关文章

  1. JavaScript编程:javaScript核心基础语法

    1.javaScript核心基础语法: javaScript技术体系包含了5个内容:          1.核心语言定义:          2.原生对象和雷子对象:          3.浏览器对象 ...

  2. JavaScript核心基础语法

    1 什么是JavaScript? 是一种嵌入在网页中的程序段. 是一种解释型语言,被浏览器解释执行. 由Netscape发明,ECMA(欧洲计算机制造商协会)将其标准化. JavaScript借用了J ...

  3. javaScript核心基础

    JavaScript 是属于网络的脚本语言! JavaScript 作用:被数百万计的网页用来改进设计.验证表单.检测浏览器.创建cookies(js也可创建cookie,在浏览器里面创建),以及更多 ...

  4. 《JavaScript核心概念》基础部分重点摘录

    注:<JavaScript核心概念>适合深入了解JavaScript,比我买的<JavaScript框架设计>语言和内容丰富多了(可能是我水平尚浅吧). 1. 作用域 var ...

  5. 最新的JavaScript核心语言标准——ES6,彻底改变你编写JS代码的方式!【转载+整理】

    原文地址 本文内容 ECMAScript 发生了什么变化? 新标准 版本号6 兑现承诺 迭代器和for-of循环 生成器 Generators 模板字符串 不定参数和默认参数 解构 Destructu ...

  6. JavaScript的基础学习

    由js和python想到的: 弱类型语言 js 中的数据在进行算数运算时,会自动转换类型强类型语言 变量的值的数据类型一旦确定,使用时不能改变 动态语言:编译时不知道数据类型,只有在执行时才知道数据类 ...

  7. 三丶JavaScript 的基础学习(一)

      知识预览 BOM对象 DOM对象(DHTML) 8 实例练习 JavaScript概述 JavaScript的历史 1992年Nombas开发出C-minus-minus(C--)的嵌入式脚本语言 ...

  8. 一.javascript核心部分:1.词法结构

    本文作为个人学习笔记,一直也没有重视javascript的系统学习(javascript是最容易被人忽视的语言),我都是要用的时候百度一下查找下资料开始用,但没有系统的,学习,和整理过javascri ...

  9. JavaScript 的基础学习(一)

    JavaScript概述 JavaScript的历史 1992年Nombas开发出C-minus-minus(C--)的嵌入式脚本语言(最初绑定在CEnvi软件中).后将其改名ScriptEase.( ...

随机推荐

  1. SpringBoot起飞系列-日志使用(四)

    一.SpringBoot中的日志组件 日志是一个系统中不可缺少的组件.在项目中,我们常用的日志组件有JUL.JCL.Jboss-logging.logback.log4j.log4j2.slf4j.. ...

  2. 接口是什么?接口长什么样?java的Interface

    今天来看看java接口长哪样.接口是特殊抽象类. 一个子类只能继承一个抽象类(父类),所以就有接口这个特殊抽象类. 下面以一个电脑的USB为例: 定义接口标准 public interface USB ...

  3. Spring boot 梳理 - Spring boot 与 JSP

    若使用Spring boot 开发web应用中使用jsp,需要打包成war,并部署到非嵌入式servlet容器中运行,在嵌入式servlet中无法运行,且需要匹配非嵌入式servlet版本与Sprin ...

  4. 读《深入理解Elasticsearch》点滴-改善查询相关性

    1.标准查询 query match _all query:"搜索字符串" operator:or 2.多匹配查询+区分权重 query multi_match "que ...

  5. Eureka实战-1【Eureka Server在线扩容】

    1.准备工作 PS:为了偷懒,每个pom文件都要依赖的公共依赖配置放在下面: <parent> <groupId>org.springframework.boot</gr ...

  6. 30 分钟快速入门 Docker 教程

    原文地址:梁桂钊的博客 博客地址:http://blog.720ui.com 欢迎关注公众号:「服务端思维」.一群同频者,一起成长,一起精进,打破认知的局限性. 一.欢迎来到 Docker 世界 1. ...

  7. MongoDB 学习笔记之 TTL索引,部分索引和文本索引

    TTL索引: TTL集合支持mongodb对存储的数据进行失效时间设置,经过指定的时间段后.或在指定的时间点过期,集合自动被mongod清除.这一特性有利于对一些只需要保存一定时间的数据信息进行存储, ...

  8. webpack loader实现

    正值前端组件化开发时代,那么必然离不开目前最火的构建工具--webpack(grunt,gulp等暂且不谈).说到这里,刚好有几个问题: 为什么运行打包命令之后,.vue 文件可以转成 .js 文件 ...

  9. win7环境搭建以太坊私链

    如何创建私链: 创建创世配置文件: 首先需要创建一个“创世”json配置文件,此文件描述了创世区块的一些参数.下面就是文件中的内容: { "coinbase": "0x0 ...

  10. Elasticsearch 7.x 之文档、索引和 REST API 【基础入门篇】

    前几天写过一篇<Elasticsearch 7.x 最详细安装及配置>,今天继续最新版基础入门内容.这一篇简单总结了 Elasticsearch 7.x 之文档.索引和 REST API. ...