博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
看看国外的javascript题目,你能全部做对吗?
阅读量:6294 次
发布时间:2019-06-22

本文共 5515 字,大约阅读时间需要 18 分钟。

正好以前也看过一篇,就借花献佛拿出来分享一下 

附带了自己的理解,答案有争议的地方欢迎大家指出

题目一

2
3
4
(
function
(){
  
return 
typeof 
arguments;
})();
 
"object"
arguments是对象,伪数组有两件事要注意这里:
参数不是数组,它是一个数组一样的物体,你可以使用方括号和整数索引的元素,但方法通常可在一个如推上不存在参数数组
Array.prototype.slice.call(arguments); 转成数组
当然arguments即使是数组,返回的依然是"object",因为数组也是对象,附加:typeof 对类型的判断
https://developer.mozilla.org/zh-CN/docs/JavaScript/Reference/Operators/typeof

题目二

2
3
var 
f =
function 
g(){
return 
23; };
typeof 
g();
会发生错误
因为function g(){ return 23; }是函数表达式,事实上只有事一个名字,不是一个函数声明
函数实际上是绑定到变量f,不是g.
指定的标识符在函数表达式虽然有其用途:堆栈跟踪是清晰而不是充斥着无名的函数,你可以有一个匿名函数递归调用本身不使用argument.callee
附非常详细的帖子函数表达式
http://kangax.github.io/nfe/

题目三

2
3
4
5
(
function
(x){
  
delete 
x;
  
return 
x;
})(1);
 
1
参数不可删除
见我发过的帖子(js中的delete定义)
http://www.cnblogs.com/aaronjs/articles/3148934.html
国外的帖子(理解删除)
http://perfectionkills.com/understanding-delete/

题目四

2
3
var 
y = 1, x = y =
typeof 
x;
x;
 
 "undefined"
通过重写代码如下结果:
var a, b; 展开就是 var a; var b;.
A = B = C;相当于 B = C = B;
知道了这一点,我们重写并得到:
var y = 1; 
y = typeof x; 
var x = y; 
x; 
当执行
y = typeof x时,x 还没有被定义,所以y成为字符串"undefined",然后被分配到x

题目五

2
3
4
(
function 
f(f){
  
return 
typeof 
f();
})(
function
(){
return 
1; });
 
 "number"
为了便于理解我们继续分解:
第一部分
var baz = function(){ return 1; }; 
第二部分
(function f(f){ 
  return typeof f(); 
})(baz); 
在这里,函数f接受一个参数是另一个函数,f函数内部执行这个实参函数并且返回类型
无论是从调用该函数返回,即使参数名称f与函数名冲突,函数接受本身作为自己的参数,然后调用,此时就看谁更具有更高的优先级了,显然,参数的优先级更高,所以实际执行的是return typeof 1

题目六

var foo = {    bar: function() { return this.baz; },    baz: 1 }; (function(){    return typeof arguments[0](); })(foo.bar);
"undefined"为什么是"undefined"?.我们必须要知道this运算符是怎么工作的.JS语言精粹总结的很精炼:1 纯粹的函数调用2 作为对象方法的调用3 作为构造函数调用4 apply调用我们看看题目是属于那种环境?在arguments[0]()中执行了一个方法,arguments[0]就是foo.bar方法注意:这在foo.bar中的this是没有绑定到foo虽然 foo.bar 传递给了函数,但是真正执行的时候,函数 bar 的上下文环境是 arguments ,并不是 fooarguemnts[0] 可以理解为 arguments.0(不过写代码就不要这样了,语法会错误的),所以这样看来,上下文环境是 arguemnts 就没问题了,所以在执行baz的时候自然this就是window了,window 上没有baz属性,返回的就是undefined, typeof调用的话就转换成"undefined"了附上博文http://www.cnblogs.com/aaronjs/archive/2011/09/02/2164009.htmlMDChttps://developer.mozilla.org/en/Core_JavaScript_1.5_Reference/Operators/Special_Operators/this_Operator#Description

题目七

var foo = {   bar: function(){ return this.baz; },   baz: 1 } typeof (f = foo.bar)();
"undefined"继续改写一下:var foo = {   bar: function(){ return this.baz; },   baz: 1 } f = foo.bar; typeof f();把foo.bar存储给f然后调用,所以this在foo.bar引用的是全局对象,所以就没有baz属性了换句话说foo.bar执行的时候上下文是 foo,但是当 把 foo.bar 赋值给 f 的时候,f 的上下文环境是 window ,是没有 baz 的,所以是 ”undefined"
 

题目八

var f = (function f(){ return "1"; }, function g(){ return 2; })(); typeof f;
"number"逗号操作符的使用可以很混淆,但这段说明它的行为:var x = (1, 2, 3); x; x的值是3,这表明,当你有一系列的组合在一起,并由逗号分隔的表达式,它们从左到右进行计算,但只有最后一个表达式的结果保存。由于同样的原因,这个问题可以改写为减少混乱:var f = (function g(){ return 2; })(); typeof f; 关于逗号表达式:原文:http://www.2ality.com/2012/09/expressions-vs-statements.html译文:http://www.cnblogs.com/ziyunfei/archive/2012/09/16/2687589.html

 

题目九

var x = 1; if (function f(){}) {   x += typeof f; } x;
"1undefined"这里有个难点if 中的 function f(){} 要如何处理?函数声明的实际规则如下:函数声明只能出现在程序或函数体内。从句法上讲,它们 不能出现在Block(块)({ ... })中,例如不能出现在 if、while 或 for 语句中。因为 Block(块) 中只能包含Statement语句, 而不能包含函数声明这样的源元素。另一方面,仔细看一看规则也会发现,唯一可能让表达式出现在Block(块)中情形,就是让它作为表达式语句的一部分。但是,规范明确规定了表达式语句不能以关键字function开头。而这实际上就是说,函数表达式同样也不能出现在Statement语句或Block(块)中(因为Block(块)就是由Statement语句构成的)。 假设代码我们不妨变一下:var x = 1;if (function(){}) {   x += typeof f; } x; var x = 1; x += typeof f; x; f在这了没有被定义,所以typeof f 是字符串"undefined" ,字符与数字相加结果也是一个字符串,所以最后的x就是"1undefined"了

题目十

(function f(){   function f(){ return 1; }   return f();   function f(){ return 2; } })();
2如果是一直看下来的话,这个题目应该是比较简单简单的来说在执行return之前,函数声明会在任何表达式被解析和求值之前先被解析和求值,即使你的声明在代码的最后一行,它也会在同作用域内第一个表达式之前被解析/求值,参考如下例子,函数fn是在alert之后声明的,但是在alert执行的时候,fn已经有定义了 alert(fn());  function fn() {    return 'Hello world!';  }所以题目中函数提升了两次,第二次把第一次覆盖了,所以 return 后面的 f 是 return 语句的下一条语句声明的函数 f 。注意自执行函数 (function f (){})(); 中的 f 并没有函数提升效果,它是表达式

题目十一

function f(){ return f; } new f() instanceof f;
false怎样去理解? new f()  首先这个操作会创建一个新对象并调用构造函数函数这一新的对象作为它的当前上下文对象简单的说 new f();依稀记得高级程序设计里面是这么说的:1 创建空对象。2 将类的prototype中的属性和方法复制到实例中。3 将第一步创建的空对象做为类的参数调用类的构造函数默认如果没有覆盖这个空对象的话,返回thisvar a = new Object;a instanceof Object    为 true我们在看 f() 返回了 return f;那么也就是说这个新的对象是是自身,构造函数本身在 new 的过程中会返回一个表示该对象的实例。但是函数的返回值覆盖了这个实例,这个new 就形同虚设果f的形式为 function f(){return this}或function f(){}就不一样var a = new f();a instanceof f  // false值得注意的是 instanceof  检测的是原型又附上我博客的 JS 对象机制深剖——new 运算符 http://www.cnblogs.com/aaronjs/archive/2012/07/04/2575570.html

题目十二

var x = [typeof x, typeof y][1];  typeof typeof x;

答案

这题目比较简单,注意下返回类型即可x = [,][1];即 x = typeof y = 'undefind'.typeof 返回的是string类型就可以了 typeof typeof必然就是'string'了.

题目十三

function(foo){   return typeof foo.bar; })({ foo: { bar: 1 } });
"undefined"又是一个恶心的题目,纯文字游戏,大家看仔细看先分解一下var baz = { foo: { bar: 1 } }; (function(foo){   return typeof foo.bar; })(baz); 去掉函数关联var baz = { foo: { bar: 1 } }; var foo = baz; typeof foo.bar; 最后,通过替代我们除去中间变量foovar baz = { foo: { bar: 1 } }; typeof baz.bar; 所以现在就很清晰了,属性中没有定义baz;它被定义为baz.foo上了,所以结果是:”undefined"

题目十四

with (function(x, undefined){}) length;
2with用得很少,with 语句就是用于暂修改作用域链的或者通常用来缩短特定情形下必须写的代码量使用with语句的JavaScript代码很难优化,因此它的运算速度比不使用with语句的等价代码要慢得多。而且,在with语句中的函数定义和变量初始化可能会产生令人惊讶的、相抵触的行为,因此我们避免使用with语句with的用法是这样的:with(object) {},在大括号里面,可以引用object的属性而不用使用object.attr这种形式。这道题里面,with接受了一个对象,只不过这个对象是函数,函数有length属性,代表形参的个数,所以上面返回的值是2mozilla withhttp://developer.mozilla.org/en/docs/Core_JavaScript_1.5_Reference:Statements:with

 

如果您看完本篇文章感觉不错,请点击一下右下角的
【推荐】来支持一下博主,谢谢!

如果是原创文章,转载请注明出处!!!

by Aaron:

转载于:https://www.cnblogs.com/webenh/p/7810250.html

你可能感兴趣的文章
spring boot集成mongodb最简单版
查看>>
DELL EqualLogic PS存储数据恢复全过程整理
查看>>
《Node.js入门经典》一2.3 安装模块
查看>>
《Java 开发从入门到精通》—— 2.5 技术解惑
查看>>
Linux 性能诊断 perf使用指南
查看>>
实操分享:看看小白我如何第一次搭建阿里云windows服务器(Tomcat+Mysql)
查看>>
Sphinx 配置文件说明
查看>>
数据结构实践——顺序表应用
查看>>
python2.7 之centos7 安装 pip, Scrapy
查看>>
机智云开源框架初始化顺序
查看>>
Spark修炼之道(进阶篇)——Spark入门到精通:第五节 Spark编程模型(二)
查看>>
一线架构师实践指南:云时代下双活零切换的七大关键点
查看>>
ART世界探险(19) - 优化编译器的编译流程
查看>>
玩转Edas应用部署
查看>>
music-音符与常用记号
查看>>
sql操作命令
查看>>
zip 数据压缩
查看>>
Python爬虫学习系列教程
查看>>
【数据库优化专题】MySQL视图优化(二)
查看>>
【转载】每个程序员都应该学习使用Python或Ruby
查看>>