那些年坑爹的JS题目
真是让人疑惑的基础。又是一堆奇怪的题目。
题目一. 应该是关于作用域的
function test(n) {
this.x = n;
return this;
}
var x = test(1);
var y = test(2);
console.log(x === y); // true
console.log(x.x, y.x); // 2 2
题目二. 关于 基本数据类型 和 引用数据类型
这题已经坑过了非常多的人。不仅仅是作为题目。
下面这两行是会报错的。
var f = function(){}
(function(){})();
下面这个就不报错,虽然和 之前的代码实际上效果是一样的。
var f = function(){}
+function(){}();
js 报错(intermediate value)(...) is not a function
题目三. JS 判断 - 极度坑爹
console.log(true == 'true'); // false
题解之高程三第三章 相等操作符 原则:
- 1.如果有一个操作数是 bool 值。则比较之前:先将 true 变为 1,false 变为 0
- 2.如果一个操作数是字符串,另一个操作数是字符,则比较之前:字符串 -> 数字(Number的方式)
- 3.如果一个操作数是对象,另外一个不是,则调用对象的 valueOf 方法。
所以,这么看的话,就不奇怪了。
console.log(true == 'true'); // false
console.log(1 == 'true'); //false
console.log(1 == parseInt('true')); //false
console.log(1 == NaN); //false
根据 NaN 的 无敌 特性: 我跟任何人都不一样(不相等).所以
console.log(false == 'true'); // false
console.log(false == 'true'); //false
console.log(false == parseInt('true')); //false
console.log(false == NaN); //false
顺便来谈谈 对象类的 判断
console.log("" == ""); // true 基本数据类型
console.log([] == []); // false 引用数据类型
console.log({} == {}); // false 引用数据类型
console.log(new String("") == new String("")); // false 引用数据类型
题目四. 函数提升问题
var f = function(){return true};
var g = function(){return false};
function g(){};
(function(){
if(g() && []!==[]) {
f = function(){return false};
function g() {return true};
}
})();
console.log(f());
console.log(g());
那些年坑爹的JS题目的更多相关文章
- 一道原生js题目引发的思考(鼠标停留区块计时)
我瞎逛个啥论坛,发现了一个题目,于是本着练手的心态就开始写起来了,于是各种问题接踵而至,收获不小. 题目是这样的: Demo: mouseenter与mouseover区别demo 跨浏览器的区块计数 ...
- 百度移动搜索自动转码太坑爹,JS跳转地址会被抓取
这段时间碰到个很崩溃的问题,一个页面通过 script 加载请求服务端进行统计再输出js进行跳转,分为两个步骤分别统计, 打开页面通过script 请求远程服务器进行统计并输出要通过js使页面跳转的最 ...
- 阿里巴巴Web前端面试的一道JS题目,求解答!!!
题目大概是这种: function outer(){ return inner; var inner = "a"; function inner(){}; inner = 9; } ...
- 【转】外国朋友出的js题目,你能对几道
原文地址 http://perfectionkills.com/javascript-quiz/ 中文地址加解释:by Aaron:http://www.cnblogs.com/aaronjs/p/3 ...
- JS题目
1.请你谈谈Cookie的弊端 cookie虽然在持久保存客户端数据提供了方便,分担了服务器存储的负担,但还是有很多局限性的. 第一:每个特定的域名下最多生成20个cookie 1.IE6或更低版本最 ...
- js题目小记
一.字符串反转 第一种方法:利用数组方法 //先split将字串变成单字数组,然后reverse()反转,然后将数组拼接回字串 var str = "abcdef"; str.sp ...
- 记录一道有意思的js题目
偶然机会,在codewars上面开始做题,遇到一道有意思的题目,记录一下: 题目是这样的: In this kata, you will write a function that returns t ...
- 几个简单的html+css+js题目
1.页面中有一图片,请在下划线处添加代码能够实现隐藏该图片的功能 <img id="pic" src="door.jpg" width="200 ...
- 有趣的js题目
([]).length ({}).length // undefined ([] + {}).length ({} + {}).length 具体解释见此.
随机推荐
- 12-18Windows窗体应用小程序之记事本(1)
一.记事本制作(1) C#结合窗体制作小程序,相比较之前的控制台应用程序可能要改善了好多,最起码界面看起来可以高仿一下了,但是最重要的还是要看其里面的功能是否实现.所以,要以实现其实用功能为主.今天利 ...
- ABP工作单元
简介 Unit of work:维护受业务事务影响的对象列表,并协调变化的写入和并发问题的解决.即管理对象的CRUD操作,以及相应的事务与并发问题等.Unit of Work是用来解决领域模型存储和变 ...
- DAY18-Django之form表单
构建一个表单 假设你想在你的网站上创建一个简单的表单,以获得用户的名字.你需要类似这样的模板: <form action="/your-name/" method=" ...
- 记录一次从txt文件导入数据的python下的MySQL实现
环境: python2.7 ComsenzXP自带MySQL 安装python-MySQL模块 数据格式:txt格式的账号信息. 数据一行一条数据. 难点:有的行只有账号,没有密码:有的为空行:有的行 ...
- [poj3686]The Windy's(费用流)
题目大意: 解题关键:指派问题,待更. #include<cstdio> #include<cstring> #include<algorithm> #includ ...
- Arduino Serial库的使用
1 Serial.begin() 2 Serial.end() 3 Serial.available() 4 Serial.read() 5 Serial.peek() 6 Serial.flush( ...
- p2501 [HAOI2006]数字序列
传送门 分析 https://www.luogu.org/blog/FlierKing/solution-p2501 对于第二问的感性理解就是有上下两条线,一些点在上面的线的上面或者下面的线的下面,然 ...
- python3-list列表增删改查合并排序
# Auther: Aaron Fan names = ["aaron", "alex", "james", "meihengfa ...
- NETTY4中的BYTEBUF 内存管理
转 http://iteches.com/archives/65193 Netty4带来一个与众不同的特点是其ByteBuf的重现实现,老实说,java.nio.ByteBuf是我用得很不爽的一个AP ...
- Altium designer的PCB设计规则
PCB布线规则,布板需要注意的点很多,但是基本上注意到了下面的这此规则,LAYOUT PCB应该会比较好,不管是高速还是低频电路,都基本如此. 1. 一般规则 1.1 PCB板上预划分数字.模拟.DA ...