JavaScript 作用域、命名空间及闭包
变量作用域:
1、一个变量的作用域是程序源代码中定义这个变量的区域
2、在函数内声明的变量是局部变量,它只在该函数及其嵌套作用域里可见(js 函数可嵌套定义);不在任何函数内声明或在函数内不使用 var 或 let 关键字声明的变量是全局变量,它在整个 JavaScript 程序里都可见
3、JavaScript 中没有块级作用域,取而代之的是函数作用域
4、局部变量会遮盖全局变量
5、注意变量的声明提前,即所有变量都会把声明提前到它的作用域顶端
6、若使用 let 声明变量,则该变量只属于就近的花括号括起来的语句块!!!
let test = "global";
function fun() {
let test = "local";
// 若改成 test = "local"; 则会修改全局变量 test
console.log("inFun: ", test);
}
fun(); // 输出 local
console.log("outFun: ", test); // 输出 global var j = 10; // 由于声明提前,所以函数内的 j != 10
function check() {
var i = 0;
// 因为函数作用域,所以会出现声明提前的现象(let 声明除外),即变量声明之前就可以使用,但其值为 undefined
console.log("j = ", j);
for (var j = 0; j < 5; ++j)
i++;
console.log("i = ", i, "j = ", j);
}
check(); // 输出 j = undefined i = 5 j = 5
命名空间:
一般情况下,在 JavaScript 中是无法声明只在一个代码块内可见的变量(let 可以声明),基于这个原因,我们常常会简单地定义一个函数用作临时的命名空间
// function 前面的左圆括号是必须的,若省略则会将关键字 function 解析为函数声明语句,
// 而不是正确地解析为函数定义表达式
var sum = (function () {
var a = 2, b = 3; // 在这里面定义的变量无法从外面访问,所以不会污染全局命名空间
return a + b;
}()); // 后面的圆括号表示结束函数定义并立即调用它
console.log(sum); // 输出 5
作用域链:
如果将一个局部变量看作是自定义实现的对象的属性的话,每一段 JavaScript 代码(全局代码或函数)都有一个与之相关的作用域链。这个作用域链是一个对象列表或链表,定义了这段代码“作用域中” 的变量。当 JavaScript 需要查找某个变量时,它会从链中的第一个对象开始查找,若未找到,则查找下一个对象,以此类推。如果作用域链上没有任何一个对象符合查找内容,则会抛出一个引用错误异常。
let global = "globalOne";
function f() {
let global = "globalTwo";
function f1() {
let global = "globalThree";
}
}
/*
在这段代码里 global 的值在作用域链里为:globalThree -> globalTwo -> globalOne,
若查询代码在 f1 里,则会从 globalThree 开始寻找,若在 f 里,则从 globalTwo 开始寻找
若找不到,则往箭头方向继续寻找下去,箭头反方向对它是不可见的
*/
闭包:
函数对象可以通过作用域链相互关联起来,函数体内部的变量都可以保存在函数作用域内,这种特性在计算机科学文献中被称为“闭包”。从技术角度讲,所有的 JavaScript 函数都是闭包
var counter = (function () {
var count = 0;
return function () {
return ++count;
};
}()); // 自我调用函数只执行一次。设置计数器为 0。并返回函数表达式。
console.log(counter()); // 输出 1
console.log(counter()); // 输出 2
console.log(counter()); // 输出 3
注:命名空间通常也是一个函数
// 同一个作用域链内定义的闭包会共享同样的私有变量或变量
// 以下代码生成 10 个闭包,所有闭包共享变量 i
function constfuncs() {
var funcs = [];
for (var i = 0; i < 10; ++i)
funcs[i] = function () {
return i; // 嵌套函数不会将作用域内的私有成员复制一份,也不会对所绑定的变量生成静态快照
};
return funcs;
}
var funcs = constfuncs(); // 当 constfuncs 返回时 i = 10
console.log(funcs[5]()); // 输出 10
JavaScript 作用域、命名空间及闭包的更多相关文章
- 个人理解的javascript作用域链与闭包
闭包引入的前提个人理解是为从外部读取局部变量,正常情况下,这是办不到的.简单的闭包举例如下: function f1(){ n=100; function f2(){ alert(n); } retu ...
- JavaScript作用域链与闭包的理解
作用域是JavaScript最重要的概念之一,想要学好JavaScript就需要理解JavaScript作用域和作用域 链的工作原理. 1. 全局作用域(Global Scope) (1)最外层函数和 ...
- 深入javascript作用域链到闭包
我之前用过闭包,用过this,虽然很多时候知道是这么一回事,但是确实理解上还不够深入.再一次看javascript高级程序设计这本书时,发现一起很多疑难问题竟然都懂了,所以总结一下一些理解,难免有错, ...
- JavaScript 作用域链与闭包
作用域链 在某个作用域访问某个变量或者函数时,会首先在自己的局部环境作用域中搜寻变量或者函数,如果本地局部环境作用域中有该变量或者函数,则就直接使用找到的这个变量值或者函数:如果本地局部环境作用域中没 ...
- javascript 作用域链及闭包,AO,VO,执行环境
下面的文章内容会根据理解程度不断修正. js变量作用域: 定义:变量在它申明的函数体以及函数体内嵌套的任意函数体内有定义. function AA(){ var bb='我是AA内部变量'; func ...
- javascript作用域和闭包之我见
javascript作用域和闭包之我见 看了<你不知道的JavaScript(上卷)>的第一部分--作用域和闭包,感受颇深,遂写一篇读书笔记加深印象.路过的大牛欢迎指点,对这方面不懂的同学 ...
- JavaScript作用域闭包简述
JavaScript作用域闭包简述 作用域 技术一般水平有限,有什么错的地方,望大家指正. 作用域就是变量起作用的范围.作用域包括全局作用域,函数作用域以块级作用域,ES6中的let和const可以形 ...
- 举例详细说明javascript作用域、闭包原理以及性能问题(转)
转自:http://www.cnblogs.com/mrsunny/archive/2011/11/03/2233978.html 这可能是每一个jser都曾经为之头疼的却又非常经典的问题,关系到内存 ...
- 【进阶2-2期】JavaScript深入之从作用域链理解闭包(转)
这是我在公众号(高级前端进阶)看到的文章,现在做笔记 https://github.com/yygmind/blog/issues/18 红宝书(p178)上对于闭包的定义:闭包是指有权访问另外一 ...
随机推荐
- 分析easyswoole3.0源码,体验es3(三)
demo在手,总得去试试看效果吧.我们先把默认的服务改成webserver,并且添加数据库的配置. 建立数据库,github里面有相关内容 CREATE TABLE `user_list` ( `us ...
- NumPy学习_01 ndarray相关概念
1.NumPy库 NumPy = Numerical Python 是高性能科学计算和数据分析的基础库. pandas库充分借鉴了NumPy的相关概念,先行掌握NumPy库的用法,才能把pandas的 ...
- 使用QML绘制界面
1 使用QML设计登录界面 https://www.cnblogs.com/bhlsheji/p/5324871.html 2 使用QML实现下拉列表框 https://blog.csdn.net/ ...
- A Model of Saliency-Based Visual Attention for Rapid Scene Analysis
A Model of Saliency-Based Visual Attention for Rapid Scene Analysis 题目:A Model of Saliency-Based Vis ...
- Codeforces 1083B The Fair Nut and Strings
Description 给定两个由 \('a'\), \('b'\) 组成的字符串 \(a\), \(b\),以及两个整数 \(n\) 和 \(k\) \(n\) 表示字符串 \(a\),\(b\) ...
- NC 自定义项参照设置为查询条件
select * from pub_query_condition where pk_templet in (select id from pub_query_templet where node_c ...
- 教你如何用ps制作紫色光斑效果
1.新建800x800画布 2.设置前景色和背景色分别为#b38adb ,#212121;执行"滤镜"-"渲染"-"云彩"操作 3.执行&q ...
- 设置tableView的组的头视图的高度
- (CGFloat)tableView:(UITableView *)tableView heightForHeaderInSection:(NSInteger)section { return 1 ...
- (PMP)第5章-----项目范围管理
产品范围:所具有的特征和功能 项目范围:必须完成的工作. 5.1 规划范围管理 输入 工具与技术 输出 1.项目章程 2.项目管理计划 (质量管理计划, 项目生命周期描述, 开发方法) 3.事业环境因 ...
- qt网络通讯出现中文乱码
转自:https://blog.csdn.net/i_fuqiang/article/details/21174227 发送: void TcpS::btn_send() { QByteArray d ...