JS作用域深度解析


Posted in Javascript onDecember 29, 2016

本文实例为大家深度剖析JS的作用域,代码注释详细,供大家参考,具体内容如下

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>作用域问题</title>
</head>
<body>
<script>
 /*
 * 1.全局变量与局部变量
 * 外层变量可以在内层调用(全局),内层变量不能在外层调用(局部)
 * */

 var a = 1;
 (function () {
  // 外部变量可以在内部调用
  alert(a);
 })();

 /*function test() {
  // 内部变量不能在外部调用
  var a = 2;
 }
 alert(a); // 报错*/

 /*
 * 下面举个例子:
 * 函数调用只是回到函数定义的地方,调用一下函数
 * 这里在bbb函数中,调用aaa函数,
 * 这时的aaa函数并不是被放入bbb函数中,而是在原定义的地方
 * 这是的aaa中没有变量a,所以去访问全局变量中的a
 * */

 /*var a = 10;
 function aaa() {
  alert(a);
 }
 function bbb() {
  var a = 20;
  aaa();
 }
 bbb(); // 10*/

 /*
 * 2.当var不加的时候,会自动变成全局变量
 * 在全局环境中,不加var和加var效果一样,都是全局变量
 * 在局域环境中,加var会被定义为局部变量,不加var会被定义为全局变量
 * */

 /*function test() {
  var a = 10; // 外部访问不到
  b = 10;  // 相当于全局变量
  // 上面相当于:var a = b = 10;
 }
 test();
 alert(b); // 10
 alert(a); // 报错*/

 /*
 * 3.变量查找按照就近原则去查找
 * var定义的变量,当就近查找没有找到就去外层查找
 * */

 /*var a = 10;
 (function() {
  var a = 20;
  // a在匿名函数中var定义了,所以找到为20
  alert(a); // 20
 })();*/

 /*var a = 10;
 (function() {
  a = 20; // 相当于全局变量,将外部的var a = 20;
  // 在匿名函数中没有找到var定义的a,然后去外层去查找
  // 外部查找到了,var a = 10 = 20;
  alert(a); // 20
 })();*/

 /*var a = 10;
 (function() {
  // 在匿名函数中没有找到var定义的a,然后去外层去查找
  // 外部查找到了,var a = 10
  alert(a); // 10
  a = 20;
 })();*/

 /*var a = 10;
 (function() {
  // 在匿名函数中找到var定义的a,
  // 这里的var a = 20,存在变量提升,
  // 在执行alert(a)之前,变量提示有var a;
  // 但是a没有值,所有返回undefined
  alert(a); // undefined
  var a = 20;

  // 在变量提升的情况下,相当于下面:
  // var a;
  // alert(a);
  // a = 20;
 })(;*/

 /*var a = 10;
 (function() {
  // 执行bbb,bbb中的a=20,但是与匿名函数和全局变量a无关
  bbb();
  // 在匿名函数中查找var定义的a,发现没有
  // 继续在外层中查找,发现了 var a = 10;
  alert(a); // 10
  function bbb() {
   var a = 20;
  }
 })();*/

 /* var a = 10;
 (function() {
  bbb();
  // 在匿名函数中查找var定义的a,发现没有
  // 继续在外层中查找,发现了 var a = 10 = 20;
  alert(a); // 20
  function bbb() {
   // 没有var定义,所有为全局变量,外面的全局变量 var a = 10 = 20;
   a = 20;
  }
 })();*/


 /*
 * 当参数与局部变量重名时,优先级等同
 * */

 /*var a = 10;
 (function (a) {
  // 这里的参数a是基本类型,按值传参的
  // 相当于在匿名函数内部重新定义了一个a,
  // 且与外层的a不相关
  a += 3;
 })(a);
 alert(a); // 10*/

 /*var a = [1,2,3];
 (function (a) {
  // 这里的参数a是特殊类型,按引用传参的
  // 相当于在匿名函数内部重新定义了一个a,
  // 但是这个a是外层a的一个别名,它们引用了同一个地址
  // 所以内部a添加值,外部a可以访问到
  a.push(4);
 })(a);
 alert(a); // [1,2,3,4]*/


 /*var a = [1,2,3];
 (function (a) {
  // 这里的参数a是特殊类型,按引用传参的
  // 相当于在匿名函数内部重新定义了一个a,
  // 但是这个a是外层a的一个别名,它们引用了同一个地址
  // 所以内部a添加值,外部a可以访问到

  // 但是,这里的a又重新赋值了新的数组,断开了与外层的关系
  a = [1,2,3,4];
 })(a);
 alert(a); // [1,2,3]*/



</script>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JQuery防止退格键网页后退的实现代码
Mar 23 Javascript
自定义ExtJS控件之下拉树和下拉表格附源码
Oct 15 Javascript
异步动态加载JS并运行(示例代码)
Dec 13 Javascript
JS实现控制表格行文本对齐的方法
Mar 30 Javascript
学习使用AngularJS文件上传控件
Feb 16 Javascript
Javascript获取background属性中url的值
Oct 17 Javascript
jQuery+pjax简单示例汇总
Apr 21 jQuery
vue 2.0封装model组件的方法
Aug 03 Javascript
vue组件表单数据回显验证及提交的实例代码
Aug 30 Javascript
微信小程序开发之左右分栏效果的实例代码
May 20 Javascript
微信小程序实现注册登录功能(表单校验、错误提示)
Dec 10 Javascript
javascript实现fetch请求返回的统一拦截
Dec 22 Javascript
javascript中的深复制详解及实例分析
Dec 29 #Javascript
canvas学习之API整理笔记(一)
Dec 29 #Javascript
Javascript Function.prototype.bind详细分析
Dec 29 #Javascript
jQuery自定义插件详解及实例代码
Dec 29 #Javascript
canvas快速绘制圆形、三角形、矩形、多边形方法介绍
Dec 29 #Javascript
JavaScript获取短信验证码(周期性)
Dec 29 #Javascript
JavaScript实现同一个页面打开多张图片
Dec 29 #Javascript
You might like
PHP 加密/解密函数 dencrypt(动态密文,带压缩功能,支持中文)
2009/01/30 PHP
PHP通过串口实现发送短信
2015/07/08 PHP
php实现给一张图片加上水印效果
2016/01/02 PHP
php 实现进制相互转换
2016/04/07 PHP
php注册审核重点解析(数据访问)
2017/05/23 PHP
学习面向对象之面向对象的术语
2010/11/30 Javascript
javascript实现div的拖动并调整大小类似qq空间个性编辑模块
2012/12/12 Javascript
document节点对象的获取方式示例介绍
2013/12/24 Javascript
JQuery 在线引用及测试引用是否成功
2014/06/24 Javascript
跟我学习javascript的prototype原型和原型链
2015/11/18 Javascript
理解javascript模块化
2016/03/28 Javascript
轻松5句话解决JavaScript的作用域
2016/07/15 Javascript
在ABP框架中使用BootstrapTable组件的方法
2017/07/31 Javascript
vue中的scope使用详解
2017/10/29 Javascript
JS实现为动态创建的元素添加事件操作示例
2018/03/17 Javascript
深入解析ES6中的promise
2018/11/08 Javascript
通过实例解析JavaScript for in及for of区别
2020/06/15 Javascript
JS数据类型判断的几种常用方法
2020/07/07 Javascript
react使用antd表单赋值,用于修改弹框的操作
2020/10/29 Javascript
微信小程序实现简单购物车功能
2020/12/30 Javascript
[50:21]Liquid vs Winstrike 2018国际邀请赛小组赛BO2 第二场
2018/08/19 DOTA
python使用cookie库操保存cookie详解
2014/03/03 Python
Python中使用HTMLParser解析html实例
2015/02/08 Python
python实现学生信息管理系统
2020/04/05 Python
Python中的取模运算方法
2018/11/10 Python
Python多继承以及MRO顺序的使用
2019/11/11 Python
锐步香港官方网上商店:Reebok香港
2020/11/05 全球购物
新书发布会策划方案
2014/06/09 职场文书
节水标语大全
2014/06/11 职场文书
销售类求职信
2014/06/13 职场文书
个人先进事迹材料
2014/12/29 职场文书
收银员岗位职责
2015/02/03 职场文书
新员工辞职信范文
2015/05/12 职场文书
刑事附带民事起诉状
2015/05/19 职场文书
法律意见书范文
2015/05/20 职场文书
vue使用v-model进行跨组件绑定的基本实现方法
2021/04/28 Vue.js