你认为你很了解Javascript?

(翻译不当之处请谅解)

来源:http://www.ido321.com/914.html

这里有5个小脚本,有助于你真正理解JavaScript核心–闭包和作用域。没有在控制台运行之前,尝试回答每个案例中会弹出什么内容,然后你可以创建一个测试文件去核对你的答案。你准备好了吗?

1、

   1: if (!("a" in window)) {
   2:     var a = 1;
   3: }
   4: alert(a);

2、

   1: var a = 1,
   2:     b = function a(x) {
   3:         x && a(--x);
   4:     };
   5: alert(a);

3、

   1: function a(x) {
   2:     return x * 2;
   3: }
   4: var a;
   5: alert(a);

4、

   1: function b(x, y, a) {
   2:     arguments[2] = 10;
   3:     alert(a);
   4: }
   5: b(1, 2, 3);

5、

   1: function a() {
   2:     alert(this);
   3: }
   4: a.call(null);

我的预测答案分别是:undefined、1、不知道、10、null

答案在本文末尾,看答案之前,你敢留下你的猜测吗?

正确答案:1、undefined   2、1   3、function a(x){ return x * 2}   4、10  5、[object window]

来源:http://dmitry.baranovskiy.com/post/91403200

时间: 2024-08-07 21:20:02

你认为你很了解Javascript?的相关文章

你认为你很了解Javascript?(个人解答)

代码来源:http://www.ido321.com/914.html 代码来源:http://dmitry.baranovskiy.com/post/91403200 纯属个人理解,欢迎大神指正. 1. 1 if (!("a" in window)) { 2 3 var a = 1; 4 5 } 6 7 alert(a); //undefined js中没有块级作用域,所以a会提前声明,"a" in window会得到true,所以并不会对a进行赋值操作 2. 1

JavaScript基础关于JSON(011)

JSON意即JavaScript Object Notation,是JavaScript里数据表示的通用格式,JSON数据格式很象JavaScript里的对象: {"name": "value", "some": [1, 2, 3]} 所不同的是,相对于对象中的属性名,在JSON中的键名,必须使用引号包起来.对象声名时只有在特殊的属性名中才需要这样做: {"first name": "Dave"}. 将一个

【JavaScript】JavaScript中的陷阱大集合

本文主要介绍怪异的Javascript,毋庸置疑,它绝对有怪异的一面.当软件开发者开始使用世界上使用最广泛的语言编写代码时,他们会在这个过 程中发现很多有趣的“特性”.即便是老练的Javascript开发者也可以在本文找到一些有趣的新陷阱,请留意这些陷阱,当然也可以尽情享受由这些陷阱 带来的“乐趣”! AD: 本文主要介绍怪异的Javascript,毋庸置疑,它绝对有怪异的一面.当软件开发者开始使用世界上使用最广泛的语言编写代码时,他们会在这个过 程中发现很多有趣的“特性”.即便是老练的Java

【JavaScript】使用面向对象的技术创建高级 Web 应用程序

本文讨论: JavaScript 是基于原型的语言 用 JavaScript 进行面向对象的编程 JavaScript 编码技巧 JavaScript 的未来 本文使用了以下技术: JavaScript   目录 JavaScript 对象是词典 JavaScript 函数是最棒的 构造函数而不是类 原型 静态属性和方法 闭包 模拟私有属性 从类继承 模拟命名空间 应当这样编写 JavaScript 代码吗? 展望 最近,我面试了一个有五年 Web 应用程序开发经验的软件开发人员.四年半来她一直

javascript里的偏函数——本质函数式编程+闭包,返回函数

除非你已经使用过其他的函数式编程,不然你可能对下面这两个概念很陌生:"偏函数应用"和"函数柯里化". 偏函数应用,英文是partial application,也可以译作"局部应用"."部分应用"."偏应用" 函数柯里化,英文是currying,也可以译作"局部套用"."加里化"."卡瑞化" 话虽如此,但是假如你一旦理解了这两个概念,你就完全可以在

【译】JavaScript 创建对象: 方法一览与最佳实践

本文是我在众成翻译上认领并翻译的:JavaScript 创建对象: 方法一览与最佳实践 在JavaScript中“创建对象”是一个复杂的话题.这门语言提供了很多种创建对象的方式,不论新手还是老手都可能对此感到无所适从,不知道应该选择哪一种.不过,尽管创建对象的方法很多,看上去语法差异也很大,但实际上它们的相似性可能比你所以为的要多.本文将带领你踏上一段梳理对象创建方法的旅程,为你揭示不同方法之间的依赖与递进关系. 对象字面量 我们的第一站毫无疑问就是创建对象最简单的方法,对象字面量.JavaSc

javascript线程解释(setTimeout,setInterval你不知道的事)

原文:http://www.iamued.com/qianduan/1645.html 今天看到这篇文章,学到了不少东西 特此发出来 和大家分享 JavaScript的setTimeout与setInterval是两个很容易欺骗别人感情的方法,因为我们开始常常以为调用了就会按既定的方式执行, 我想不少人都深有同感, 例如 setTimeout( function(){ alert('你好!'); } , 0); setInterval( callbackFunction , 100); 认为se

javascript对象的属性,方法,prototype作用范围分析

读了篇博客感觉很有用"javascript对象的属性,方法,prototype作用范围分析"就自己写了一遍.以后自己可以用的到. 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 2 <html xmlns="http://

JavaScript - 收藏集 - 掘金

Angular 中的响应式编程 -- 浅淡 Rx 的流式思维 - 掘金第一节:初识Angular-CLI第二节:登录组件的构建第三节:建立一个待办事项应用第四节:进化!模块化你的应用第五节:多用户版本的待办事项应用第六节:使用第三方样式库及模块优化用第七节:给组件带来活力Rx--隐藏在 Angular 中的利剑Redux你的 A... Electron 深度实践总结 - 前端 - 掘金思维导图 前言: Electron 从最初发布到现在已经维护很长一段时间了,但是去年才开始慢慢升温.笔者个人恰好