摘要:属性返回所属函数的函数名称。正确字符串如果格式错误构造函数返回的仍是一个的实例所以结果为第题解析一个的属性就是参数的个数。的结果中国标准时间,获得当前时间是个对象,是获得当前时间是个字符串。
第23道
[1 < 2 < 3, 3 < 2 < 1]
解析:如果加上括号就清楚了许多。
(1 < 2) < 3 => (true) < 3 => 1 < 3 => true
(3 < 2) < 1 => (false) < 1 => 0 < 3 => true
所以结果为 [true, true]
第24题2 == [[[2]]] //是真还是假?
解析:让我们来看看类型转换。
引用类型转换为基本类型(所有的引用类型转换为布尔值都是true)
引用类型转换为字符串
1.优先调用toString方法(如果有),看其返回结果是否是原始类型,如果是,转化为字符串,返回。 2.否则,调用valueOf方法(如果有),看其返回结果是否是原始类型,如果是,转化为字符串,返回。 3.其他报错。
引用类型转化为数字
1.优先调用valueOf方法(如果有),看其返回结果是否是基本类型,如果是,转化为数字,返回。 2.否则,调用toString方法(如果有),看其返回结果是否是基本类型,如果是,转化为数字,返回。 3.其他报错。
valueOf()得到的都是对象本身,toString()方法转为字符串就不用说了.
以下来自犀牛书:
1,null和undefined,相等。
2,数字和字符串,转化为数字再比较。
3,如果有true或false,转换为1或0,再比较。
4,如果有引用类型,优先调用valueOf。
5,其余都不相等。
回到本题,调用valueOf()返回的是本身不是基本类型,然后调用toString()得到"2",然后变成了字符串和数字("2" == 2)进行比较。
所以结果为 true
第25题3.toString(); 3..toString(); 3...toString();
解析:.在JS里是方法的调用的一种写法,但是数字也是可以有小数点的。你用3.toString()会将其解析为一个带小数点的数字,不会调用。
以下可以成功转换
(3).toString(); 3..toString(); "" + 3; String(3);
所以结果为 error "3" error
第26题(function () { var x = y =1; })(); console.log(y); console.log(x);
解析:此时x是局部变量但是y是全局变量。在外部试图访问内部变量x时会出现错误。
所以结果为 1 error
第27题var a = /123/, b = /123/; a == b; a === b;
解析:ab都是正则,正则也是对象。
2个引用的是同一个对象、函数、数组,则它们相等,如果引用的不是同一个对象、函数、数组,则不相同,即使这2个对象、函数、数组可以转换成完全相等的原始值。
所以结果为 false false
第28题var a = [1, 2, 3], b = [1, 2, 3], c = [1, 2, 4]; a == b a === b a > c a < c
解析:同上题。比较大小时,就按照字典序比较。
所以结果为 false false false true
第29题var a = {}, b = Object.prototype; [a.prototype === b, Object.getPrototypeOf(a) === b]
解析:只有函数才会有prototype属性,所以a.prototype为udnefined。Object.getPrototypeOf(obj)返回一个具体对象的原型(该对象的内部[[prototype]]值)
所以结果为 false true
第30题function f() {} var a = f.prototype, b = Object.getPrototypeOf(f); a === b;
解析:var f1 = new f()此时f1是一个从f.prototype继承而来的对象(f1是一个实例对象),f.prototype是使用new创建的实例(f1)的原型。所以a是实例的原型,而b是f的原型。所以a不同于b。
参考:继承与原型链
var o = {a: 1}; //o这个对象继承了Object.prototype上面的所有属性 //原型链如下o > Object.prototype > null var a = ["uo", "waht"]; //数组都继承Array.prototype //原型链如下a > Array.prototype > Object.prototype > null function f() {} //函数都继承Function.prototype //原型链如下f > Function.prototype > Object.prototype > null
所以结果为 false
第31题function foo() { } var oldName = foo.name; foo.name = "bar"; [oldName, foo.name] //输出什么?
解析:(╯‵□′)╯︵┻━┻。name属性返回所属函数的函数名称。Bloody Hell!
参考Function.name
var object = { firstMethod: function first() {}, secondMethod: function () {} }; console.log(object.firstMethod.name); //first console.log(object.secondMethod.name); //""
另外函数的name属性不能被更改,因为它是只读的。
所以结果为 ["foo", "foo"]
第32题"1 2 3".replace(/d/g, parseInt)
解析:和第一题还是很类似的。
str.replace(/d/g, function ($0, $1, $2.. , index, string) { }) //$0匹配的子串 $1第一个括号匹配的字符串 。。。类推
由于没有分组,所以相当于
parseInt("1", 0); //1 parseInt("2", 2); //NaN parseInt("3", 4); //3
所以结果为 [1, NaN, 3]
第33题function f() {} var parent = Object.getPrototypeOf(f); f.name // ? parent.name // ? typeof eval(f.name) // ? typeof eval(parent.name) // ?
解析:由30题和31题,可以得到答案。parent === Function.prototype
所以答案为 "f", "", "function", error
第34题var lowerCaseOnly = /^[a-z]+$/; [lowerCaseOnly.test(null), lowerCaseOnly.test()]
解析:test函数会将参数转换为字符串。"null"和"undefined"。
所以结果为 [true, true]
第35题[,,,].join(", ")
解析:真恶心还允许最后一个元素后跟一个,!长度为3的稀疏数组,但是并没有属性。
所以结果为 [, , ]
第36题var a = {class: "Animal", name: "Fido"}; a.class
解析:与浏览器有关。Chrome下结果为"Animal"
第37题var a = new Date("epoch")
解析:Date()可以接受一个字符串,该字符串应该能被Date.parse()方法识别。
//正确字符串 Date.parse("Wed, 09 Aug 1995 00:00:00") //如果格式错误 构造函数返回的仍是一个Date 的实例 Invalid Date.
所以结果为 Invalid Date
第38题var a = Function.length, b = new Function().length; a === b; //?
解析:一个function的length属性就是参数的个数。另外Function.length定义为1
所以结果为 false
第39题var a = Date(0); var b = new Date(0); var c = new Date(); [a === b, b === c, a === c]
解析:不传入参数获得当前时间。b的结果Thu Jan 01 1970 08:00:00 GMT+0800 (中国标准时间),c获得当前时间是个对象,a是获得当前时间是个字符串。
所以结果为 [false, false, false]
第40题var min = Math.min(), max = Math.max() min < max //?
解析:Math.min()不传参数返回Infinity,Math.max()不传参数返回-Infinity
所以结果为 false
结束终于结尾了。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/81724.html
摘要:表示要解析的数字的基数。得到的是,但是注意与所有值都不相等包括本身。所以结果为第题解析属性表示在中所能表示的最小的正值。属性是里最接近的正值,而不是最小的负值。 原文题目来自:http://javascript-puzzlers.he...参考的解答:http://www.admin10000.com/doc... 第一道: [1, 2, 3].map(parseInt) 解析:.ma...
摘要:跨域请求详解从繁至简前端掘金什么是为什么要用是的一种使用模式,可用于解决主流浏览器的跨域数据访问的问题。异步编程入门道典型的面试题前端掘金在界中,开发人员的需求量一直居高不下。 jsonp 跨域请求详解——从繁至简 - 前端 - 掘金什么是jsonp?为什么要用jsonp?JSONP(JSON with Padding)是JSON的一种使用模式,可用于解决主流浏览器的跨域数据访问的问题...
摘要:前后经过九个月,我翻译的官方版本中文文档可以发布第一个较为完整的版本了。这点原本是最重要的,但让位于符合中文习惯,是因为如果译本有机翻痕迹,给人的品质感和可信度就降低了更准确和更优雅的翻译风格。 showImg(/img/remote/1460000006773992); 前后经过九个月,我翻译的Spring MVC官方4.2.4版本中文文档可以发布第一个较为完整的版本了。译文上尽量做...
阅读 3566·2023-04-26 02:32
阅读 3712·2021-11-23 10:05
阅读 2264·2021-10-08 10:04
阅读 2662·2021-09-22 16:06
阅读 3586·2021-09-22 15:27
阅读 727·2019-08-30 15:54
阅读 1615·2019-08-30 13:50
阅读 2580·2019-08-29 13:56