js:语言精髓笔记10--闭包】的更多相关文章

闭包:  //JS函数式风格中,在内部保存数据和对外无副作用这两个特性主要就是通过闭包实现的: 函数与闭包: 一个函数是一段静态代码,它是一个代码书写时已经编译期,静态概念:闭包是函数在代码运行过程中产生的一个动态环境,是一个运行期,动态的概念: 函数引用和函数实例://在被调用时,每个函数实例至少拥有一个闭包: //函数引用 function myFunc2() { }; var f1 = myFunc2; var f2 = myFunc2; console.log(f1 === f2); /…
语言:程序最终被表达为数据(结构)和逻辑(算法),命令式和说明式/函数式语言分别从这两方面分类: 动态:在语言陈述时无法确定,必须在计算机执行时才能确定语言关系:JS是完全动态语言,导致其不确定性一般包括: 标识符确定:表现为动态类型,动态重写,动态存取数据结构: 语句上下文确定:表现为动态变量/语法作用域,闭包作用域: 起源: 动态数据类型: 动态类型声明(动态类型绑定):语言变量是无类型的,只有在赋值后才有某种类型: 动态空间分配(动态数据绑定):变量在赋值时才会分配空间: 动态执行系统:…
形式化运算系统的研究: 图灵:提出图灵机形式系统,通过0,1运算系统来解决复杂问题: 冯诺依曼:提出了冯诺依曼体系:即通过修改内存反映运算结果: 阿隆左.丘奇:提出新的运算范型Lambda演算,计算机运算才是本质,修改内存只不过是这种运算规则的副作用: 后出现函数式语言的鼻祖:LISP; 函数式语言: 通过连续表达式运算求值的语言; 由于现在的计算机都是基于冯诺依曼体系建立的,所以函数式语言就是运行在解释环境而非编译环境的: 结果:大多数人都在使用基于冯诺依曼体系的命令式语言,但为了获得特别的计…
对于括号内: 通过赋值时发生的重写: (Object1 = function() {}).prototype.value = 100; var obj1 = new Object1; console.log(obj1.value); // 100 语法声明阶段的重写: //会报错,一般引擎不承认在表达式中声明的标识符: (function Object2() {}).prototype.value = 100; 重写: 对内部对象系统的影响: 重写内置构造器:任意构造器的原型属性不受内置构造器重…
封装: 一把对象系统,封装是由语法解析来实现的,即语法作用域:但js是动态语言,因此只能依赖变量作用域: js的变量作用域只有表达式,函数,全局三种:所以js只能实现public和private两种封装性;            //js中类表现为构造器: function MyObject () { //private var data = 100; function _run(v) { alert(v); } //pbulic this.value = 'the data is '; thi…
面向对象有三个基本特性:封装,继承,多态:如果都满足的话称为面向对象语言:而部分满足则称为基于对象语言: 数据类型实现模型描述: JavaScript对象模型: 构造过程:函数->构造器 构造器首先是一个函数,可以理解为函数初始化的时候其prototype是无值的,只有在需要引用到原型时,才具有构造器的的特性: 函数的原型总是一个标准的.系统内置的Object()构造器的实例: 该实例创建后construct属性总先被赋值为当前函数; 继承复制: 构造复制:每构造一个实例就从原型中复制一个映像,…
计算模型:源于对计算过程的不同认识: 1.基于不同计算模型一般分为://教科书的一般分类 命令式语言: 函数式语言: 逻辑式语言: 面向对象程序设计语言: 2.基于程序本质分类:  //编程的经典法则:算法+数据结构=程序: 命令式:   //基于数据结构 结构化编程(冯诺依曼:计算机系统以存储和处理为核心)[面向存储的编程]: 面向对象编程: 说明式:   //基于算法 函数式: 其他: 命令式语言面临的问题:如何抽象数据存储: 结构化编程:通过运算去改变内存: 结构: 控制结构:顺序,分支,…
表达式:由运算符和运算元构成:JS中没有运算符的表达式称为单值表达式:没有运算元,孤立与代码上下文的运算符是不符合语法的:(表达式是有返回值的) 单值表达式: this引用: 变量引用: 直接量: null undefined 字符串 布尔值 数值 正则表达式 基本表达式: 单值表达式 数组初始器:[] 对象初始器:{} 表达式分组运算:()  运算符按结果值的分类: 一般表达式运算:(会强制类型转换) 数值运算                                          …
标识符: 命名: 语法以及类型----语法关键字                                           //逻辑 值(的存储位置)----变量和常量                                    //值 绑定://位置 语法关键字对位置的绑定----作用域限定 变量对位置的绑定---变量生存周期的限定 声明:约定变量的生存周期和作用域: 标识符语义关系: 与值相关: 类型 变量: 直接量 对象 与逻辑相关: 控制流程语句: 标签声明 一般流程…
消除代码全局变量名占用: //本质是使用匿名函数: void function(x, y, z) { console.log(x + y + z); }(1,2,3); //要使函数内的变量不被释放,需要使用引用: 一次性的构造函数: //维护原型链,保证标识符重写后,实例.constructor仍指向构造器: var Instance = function() {}; Instance.prototype = { constructor: Instance } Instance = new I…