javascript专业八级测试答案整理

最近亚马逊书满减,凑单买了本javascript实用代码段的书,结果发现原来那个所谓八级测试的始作俑者就是这本··· 结果竟然没有答案···

遂觉得还是整理一遍的好,加上之前自己的一些笔记,和一些扩展,写个总结发出来记录一下。

1,

  1. ["1", "2", "3"].map(parseInt)

这东西无非是函数参数问题,记得住就答得出来,真没什么卵用。

主要是parseInt的第二个参数,是解析数字的基数,也就是进制,范围为2~36。

比如这道题的第二个运行结果 就是 parseInt(‘2‘,1);  参数不符 故是NAN。

第二个运行结果 parseInt(‘3‘,2); 二进制里没有3,所以也是NAN。

2

  1. [typeof null, null instanceof Object]

null,array的 typeof 都是object。

但是instanceof还是很严谨的。

不过以下需要注意:

1. instanceof 是判断前者是否为后者的一个实例,所以

2.判断一个变量的类型上面两种都不好要用这个:

Object.prototype.toString.call(XXX).slice(8,-1);

3

  1. [ [3,2,1].reduce(Math.pow), [].reduce(Math.pow)] ]

这个就是新array api的熟悉啦,

reduce也支持两个参数,arr.reduce(callback[, initialValue])   第二个参数··· 就叫他迭代开始吧, arr和initialValue两个参数不能同时为空,上一道题就是同时为空了。

链接里给的答案解析是有一些小问题的。

4是操作符优先级问题,就不说了。

5

这道题涉及的东西是作用域和变量声明。

javaScript是没有块级作用域的,只有函数作用域。所以

if(true){var hehe = ‘hehe‘}这样写是没错误的。

因为作用域是一样的,当然还有最关键的一点,就是js的提前声明。

代码等同于:

  1. var name = ‘World!‘;
  2. (function () {
  3. var name;
  4. if (typeof name === ‘undefined‘) {
  5. name = ‘Jack‘;
  6. console.log(‘Goodbye ‘ + name);
  7. } else {
  8. console.log(‘Hello ‘ + name);
  9. }
  10. })();

所以name是undefined;

6 js最大的数是2^53。

7 pass

8

js没有精确的数值,是因为十进制在转换为计算机用二进制时候的丢失导致的。该死的js并没有对这个误差进行处理。

9,10

switch 用 === 进行枚举,记住即可。

另外周同学上次在社区 群里提到的:

=== 是不触发toString的。

11 pass

12 同1

13 pass

14

  1. var a = [0];
  2. if ([0]) {
  3. console.log(a == true);
  4. } else {
  5. console.log("wut");
  6. }

if的判断

==和if的判断是不一样的

比如 if(2) 是true,但是 2 == true 是false,因为在==时,是把布尔值转换为数字类型在进行比较,这个时候 true是1,所以在==时,只有1==true是 ture。

同样的在if里,数字类型只有0是false,因为其余的转为布尔类型是,都是true。

引用对象都为true

小tips

1: 条件语句可以用 && 代替 比如  a&& b  就是if(a) && b

2:别的语言喜欢把-1当做false,放在js里,你可以用 if(~flag) 来使-1返回false。

~是按位取反,按照取反再减一来运算,

比如你要判断indexof

那么 if(~xxx.indexof(‘x‘) ) 比 if(xxx.indexof(‘x‘) > -1) 漂亮的多。

15

  1. []==[]

无论是== 还是=== 判断的都是索引值。

=赋予的也是对象的索引,所以千万不要 a=b=[] 这样子赋值,会是噩梦的。

16

  1. ‘5‘ + 3
  2. ‘5‘ - 3

53和2,因为在遇到减号时,会先转换为数值类型。

那么 3 + ‘5’ - 3是多少呢? 是32。

那如果我们要字符串类型转换为数字类型呢?

+str  或者 str*1。

像上面那样 str在中间,就尽量用*1吧 、

17

我不明白,也没找到··· 试了好多组数字,找到了点规律··· 但是依旧不明白为什么···

18 pass

19 arguments,严格模式下就不会被更改了。

相应的,还有一个全局变量undefined,在严格模式下也不会可以被修改。

但是你依旧可以用function undefined来修改。

有的闭包会传一个undefined的参数,就是怕在全局被复写了。

20,21,22,23,

pass

24

2.toString() 报错是因为解析器把‘.‘解析为了浮点数的‘.‘。所以如果你要用写符合这种语义的代码就要:

25

  1. (function(){
  2. var x = y = 1;
  3. })();
  4. console.log(y);
  5. console.log(x);

y是全局。

来点复杂的,还记得那三道面试题吗?

  1. var a = 10;
  2. function test() {
  3. a = 100;
  4. alert(a);
  5. alert(this.a);
  6. var a;
  7. alert(a);
  8. }
  9. test();

答案是 100 10 100

因为

  1. var a = 10;
  2. function test() {
  3. var a;
  4. a = 100;
  5. alert(a);
  6. alert(this.a);
  7. //var a; 声明提前
  8. alert(a);
  9. }
  10. test();

这里还涉及到了一个作用域问题。

最后统一说一下吧。

  1. var a = 100;
  2. function test(){
  3. alert(a);
  4. var a = 10;
  5. alert(a);
  6. }
  7. test();

同样是声明提前 所以 第一个alert是undefined。

  1. var a = 100;
  2. function test(){
  3. alert(a);
  4. a = 10; //去掉了var 就变成定义了全局变量了
  5. alert(a);
  6. }
  7. test();
  8. alert(a);

这个最简单其实,别被前两个弄蒙就ok了。

26

记住即可

27同15

28,29, pass

30

  1. function foo() { }
  2. var oldName = foo.name;
  3. foo.name = "bar";
  4. [oldName, foo.name]

function的name问题。

  1. function foo() {}
  2. alert(foo.name)
  3. var foo2 = function (){}
  4. alert(foo2.name)

那这道题呢?

答案是 foo,undefined。

因为第二个是吧匿名函数复制给了foo2,所以没有name。

谢谢周同学为我解惑。

31 同1

32 同30

33 pass

34

  1. [,,,].join(", ")

arr允许最后一个为逗号。

还记得那个最简单的验证ie浏览器的代码吗?

!+[1,]

就是因为低版本(9以前?忘记了)的bug,[1,]在ie下toString是1,而不是1。

35

别用关键字,总不会出问题。

ok,大概就这些。在说一下这里面很少涉及的this问题。

构造函数是有作用域的

所以

a,b() 这种类型的作用域就是a。

但是····要记住this只在执行时才会绑定,所以

当你把a.b 付给了c时候,this有指向了全局了···

那么如果这样呢?

里面外面都是一样的,当你执行的是 func() 的时候,都会指向全局。

时间: 2024-10-06 15:03:00

javascript专业八级测试答案整理的相关文章

javascript 最常用的技巧整理

1. oncontextmenu="window.event.returnValue=false" 将彻底屏蔽鼠标右键<table border oncontextmenu=return(false)><td>no</table> 可用于Table 2. <body onselectstart="return false"> 取消选取.防止复制 3. onpaste="return false" 不

(转)你没有成为专业的测试人员,原因何在?

1.你认为测试并不是一份技术性的职业,所以并不去尝试学习理解产品的编码 如果你从事的是软件开发,至少会理解一些软件工程的知识.而作为测试人员,你应该能够读懂代码来分析产品,来理解代码的变更和修复将会如何引入其他的bug.黑盒vs白盒的日子应该结束了. 如果你不想这样,即使不用写任何代码依然可以从事该工作.但是如果你不去读代码,将会失去对整个测试流程很重要的一项投入. 2.只有当开发人员告知开始测试时才真正介入到整个流程中 大家如实的回答,在整个开发流程中何时开展测试的? 理论上我们想在需求收集分

JavaScript 内存释放测试

JS内部实现垃圾回收机制 无法立即释放 只要数据没有依赖关系 就会在下轮内存回收时清理 ! function () { var array = [] , count = 100*100*100*5 , time = +new Date ; while( count-- ) array.push( document.createElement('el') ) ; console.log( +new Date - time, array.length ) ; count = 100*100*100*

JavaScript专业规则12条

学习JavaScript是困难的.它发展的如此之快,以至于在任何一个特定的时刻,你都不清楚自己是否“做错了”.有些时候,感觉像是坏的部分超过了好的部分.然而,讨论这些并没有意义,JavaScript正在征服世界,所以,我们也只能这么做了. 下面是我的一些建议: 1.JS应该放到 .js 文件中 “额,只有那么几行而已…”,是的,我的意思是所有的 JS 都应该放在 .js 文件中.为什么呢?因为这有助于可读性,节省带宽.行内 JavaScript 在每次页面加载时都会重新下载,相反的,单独的 .j

最全的web前端面试题及答案整理 你不得不看

面试web前端开发,不管是笔试还是面试,都会涉及到各种专业技术问题,今天小编整理了一些常见的web前端面试题及答案,希望对大家有所帮助. 1.常用那几种浏览器测试?有哪些内核(Layout Engine)? (Q1) 浏览器:IE,Chrome,FireFox,Safari,Opera. (Q2) 内核:Trident,Gecko,Presto,Webkit. 2. 说下行内元素和块级元素的区别?行内块元素的兼容性使用?(IE8 以下) (Q1) 行内元素:会在水平方向排列,不能包含块级元素,设

深入理解JavaScript系列(20):《你真懂JavaScript吗?》答案详解

介绍 昨天发的<大叔手记(19):你真懂JavaScript吗?>里面的5个题目,有很多回答,发现强人还是很多的,很多人都全部答对了. 今天我们来对这5个题目详细分析一下,希望对大家有所帮助. 注: 问题来自大名鼎鼎的前端架构师Baranovskiy的帖子<So, you think you know JavaScript?>. 答案也是来自大名鼎鼎的JS牛人Nicholas C. Zakas的帖子<Answering Baranovskiy’s JavaScript qui

25 个最基本的 JavaScript 面试问题及答案

1.使用 typeof bar === "object" 来确定 bar 是否是对象的潜在陷阱是什么?如何避免这个陷阱? 尽管 typeof bar === "object" 是检查 bar 是否对象的可靠方法,令人惊讶的是在JavaScript中 null 也被认为是对象! 因此,令大多数开发人员惊讶的是,下面的代码将输出 true (而不是false) 到控制台: var bar = null; console.log(typeof bar === "

25个最基本的JavaScript面试问题及答案

1.使用 typeof bar === "object" 来确定 bar 是否是对象的潜在陷阱是什么?如何避免这个陷阱? 尽管 typeof bar === "object" 是检查 bar 是否对象的可靠方法,令人惊讶的是在JavaScript中 null 也被认为是对象! 因此,令大多数开发人员惊讶的是,下面的代码将输出 true (而不是false) 到控制台: var bar = null; console.log(typeof bar === "

前端面试题及答案整理(一)(转)

各公司秋招很快就开始了,最近在准备面试的东西,干脆将发现的各类 面试题整理一下共享出来,大部分面试题是没有标准答案的,我给出的答案也是仅供参考,如果有更好的解答欢迎在评论区留言. Part1 手写代码 现场手写代码是现在面试中很常见的一类面试题,考察基础的数据结构与算法能力. 1 数组去重的实现 基本数组去重 Array.prototype.unique = function(){ var result = []; this.forEach(function(v){ if(result.inde