热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

作用域链&&严厉形式

作用域链迷惑性代码vara100;functiontest(){console.log(a);}functiontestFun(){vara200;test();}不假思索的想到出

作用域链

  1. 迷惑性代码

var a = 100;
function test(){
console.log(a);
}
function testFun(){
var a = 200;
test();
}

不假思索的想到 出版的一定是 200啊 ,但是严严实实被打脸,输出 100

缘由

在编译时,

  1. 全局作用域中会存有的对象

    • a
    • test
    • testFun
  2. testFun作用域中存的

    • a
  3. test

在运行时,

test() 我这里须要变量a 啊,但是在test的作用域中并不存在,那末就须要去全局作用域中寻觅 a,报告老大找到了,输出全局作用域中的a,输出100

  1. 迷惑性代码

var a = 100;
function testFun2(){
var a = 300;
function test(){
console.log(a)
}
test();
}
testFun2();

输出什么? 300!

?!为何呢

作用域链再走一波

1.全局作用域

    • a
    • testFun2
    1. testFun2

      • a
      • test
    2. test

    运行时test时,报告老大,我须要变量a ,test作用域:我没有啊,你去看看testFun2有无;
    testFun2作用域:我有 给你拿去好了;
    输出 300

    严厉形式

    实例

    'use strict';
    x = 3.14; // 报错(x 未定义)

    'use strict'
    myFunction();
    function myFunction(){
    y = 3.14; // 报错 (y 未定义)
    }

    // 不允许删除变量或对象
    'use strict';
    var x = 3.14;
    delete x ;

    // 不允许删除函数
    'use strict';
    function x(p1,p2){};
    delete x ;
    // 报错

    // 不允许变量重名
    'use strict';
    function x(p1,p1){} // 报错

    // 不允许运用八进制
    'use strict';
    var x = 010; // 报错

    // 不允许运用转义字符
    'use strict';
    var x= \010; // 报错

    // 不允许对只读属性赋值
    'use strict';
    var obj ={};
    Object.defineProperty(obj,'x',{value:0,writable:false});
    obj.x = 3.14;

    // 不允许对一个运用 getter要领读取的属性举行赋值
    'use strict';
    var obj ={get x(){return 0}};
    obj.x=3.14; // 报错

    // 变量名 不能运用 'eval'字符串
    'use strict';
    var eval = 3.14; // 报错

    //变量名不能运用 'arguments'字符串
    'use strict';
    var arguments = 3.14; //报错

    // 制止 this 关键字指向全局对象
    function test(){
    console.log(this); // undefined
    }

    严厉形式新增的一些保存关键字
    • implements
    • interface
    • let
    • package
    • private
    • protected
    • public
    • static
    • yield

    推荐阅读
    • 本文深入探讨了Go语言中的接口型函数,通过实例分析其灵活性和强大功能,帮助开发者更好地理解和运用这一特性。 ... [详细]
    • 函子(Functor)是函数式编程中的一个重要概念,它不仅是一个特殊的容器,还提供了一种优雅的方式来处理值和函数。本文将详细介绍函子的基本概念及其在函数式编程中的应用,包括如何通过函子控制副作用、处理异常以及进行异步操作。 ... [详细]
    • 深入理解Java SE 8新特性:Lambda表达式与函数式编程
      本文作为‘Java SE 8新特性概览’系列的一部分,将详细探讨Lambda表达式。通过多种示例,我们将展示Lambda表达式的不同应用场景,并解释编译器如何处理这些表达式。 ... [详细]
    • ASP.NET 进度条实现详解
      本文介绍了如何在ASP.NET中使用HTML和JavaScript创建一个动态更新的进度条,并通过Default.aspx页面进行展示。 ... [详细]
    • 本文探讨了如何在 Spring MVC 框架下,通过自定义注解和拦截器机制来实现细粒度的权限管理功能。 ... [详细]
    • 长期从事ABAP开发工作的专业人士,在面对行业新趋势时,往往需要重新审视自己的发展方向。本文探讨了几位资深专家对ABAP未来走向的看法,以及开发者应如何调整技能以适应新的技术环境。 ... [详细]
    • 本文探讨了如何通过优化 DOM 操作来提升 JavaScript 的性能,包括使用 `createElement` 函数、动画元素、理解重绘事件及处理鼠标滚动事件等关键主题。 ... [详细]
    • 入门指南:使用FastRPC技术连接Qualcomm Hexagon DSP
      本文旨在为初学者提供关于如何使用FastRPC技术连接Qualcomm Hexagon DSP的基础知识。FastRPC技术允许开发者在本地客户端实现远程调用,从而简化Hexagon DSP的开发和调试过程。 ... [详细]
    • 1.绑定htmlcss1.1对象语法:  传给v-bind:class一个对象,以动态地切换class   ... [详细]
    • 数据类型--char一、char1.1char占用2个字节char取值范围:【0~65535】char采用unicode编码方式char类型的字面量用单引号括起来char可以存储一 ... [详细]
    • 本文详细介绍了如何利用 Bootstrap Table 实现数据展示与操作,包括数据加载、表格配置及前后端交互等关键步骤。 ... [详细]
    • 本文介绍了一种方法,通过使用Python的ctypes库来调用C++代码。具体实例为实现一个简单的加法器,并详细说明了从编写C++代码到编译及最终在Python中调用的全过程。 ... [详细]
    • 本文介绍如何使用JavaScript中的for循环来创建一个九九乘法表,适合初学者学习循环结构的应用。 ... [详细]
    • 本文探讨了异步编程的发展历程,从最初的AJAX异步回调到现代的Promise、Generator+Co以及Async/Await等技术。文章详细分析了Promise的工作原理及其源码实现,帮助开发者更好地理解和使用这一重要工具。 ... [详细]
    • Bootstrap Paginator 分页插件详解与应用
      本文深入探讨了Bootstrap Paginator这款流行的JavaScript分页插件,提供了详细的使用指南和示例代码,旨在帮助开发者更好地理解和利用该工具进行高效的数据展示。 ... [详细]
    author-avatar
    787849993_8c653d
    这个家伙很懒,什么也没留下!
    PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有