JS稀奇古怪题目:

1.操作对象属性优先级高于普通赋值操作

     var a = {
n: 1
};
var b = a; //操作对象属性优先级高于普通赋值操作
a.x = a = {
n: 2
}; console.log(a.n, b.n); // 2 1
console.log(a.x, b.x); //undefined Object

2.作用域只有局部和全局,没有对象作用域。

只能查找局部和全局作用域

 var obj = {
fn2:function(){
console.log(fn2);
}
}
obj.fn2(); //error: fn2 is not defined

修改绑定当前调用对象obj

 var obj = {
fn2:function(){
console.log(this.fn2);
}
}
obj.fn2(); //function(){console.log(this.fn2);}

3.变量提升

 var a = 2;
function fn(){
//局部变量提升
console.log(a);
var a = 3; }
fn(); //undefined function fn2(){
console.log(a);
a = 3; }
fn2(); //2 [局部没有a,全局此时为2,之后为3]

只看全局和function作用域不看if则if中的var name 变量提升了:

 var name = "hello";

 (function(){
if(typeof name === 'undefined'){
var name = 'world';
console.log(name);
}else{
console.log(name);
}
})(); //word

4.同名变量和函数

首先变量提升,但函数声明总是覆盖同名变量

  • 如果同名变量没有赋值,则类型一定是function
  • 如果同名变量赋值了,

    • 如果打印语句在赋值之后,则类型一定是number
    • 如果打印语句在赋值之前,则类型一定是function

(1)变量在函数前且有赋值

 var b;
function b(){ }
console.log(typeof b); //function console.log(typeof b); //function

(2)变量在函数前且无赋值

 var b = 3;
function b(){ }
console.log(typeof b); //number console.log(typeof b); //number

(3)变量在函数后且无赋值

 function b(){

 }
var b;
console.log(typeof b); //function console.log(typeof b); //function

(4)变量在函数后且有赋值

 function b(){

 }
var b = 3;
console.log(typeof b); //number console.log(typeof b); //number

5.线程

主线程执行完毕之后,在从callback queue中取回调函数执行

var a = 6;
setTimeout(function(){
console.log(0);
alert(a);
a = 666;
},0); console.log(1);
a = 66;

执行主线程: 打印1,然后a = 66,在执行定时器回调函数打印0,弹框值66

6.原型链

注意:是在Function的原型上加方法,不是在F函数对象上加方法

 // var F = function(){}

 function F(){

 }

 Object.prototype.a = function(){
console.log("a()");
} Function.prototype.b = function(){
console.log("b()");
} var f = new F(); F.a();//a()
F.b();//b()
f.a();//a()
f.b();//报错

JS稀奇古怪题目的更多相关文章

  1. JS经典题目解析

    此次列举出一些觉得有意思的JS题目(来源于出了名的44题),相信有非常多关于这些题目的博客,写这篇博客的目的在于巩固一些知识点,希望能和读者共同进步. 1. map函数执行过程 ["1&qu ...

  2. 一道短小精悍的JS小题目

    看到题目你是不是以为我在开车,没错,我就不承认,你能咋的,你瞅啥,别瞅我,瞅题 题目是这样式的 结果是啥呀,这里我就不买关子了,结果是undefined,相信基础好一点的大佬们一眼就能看出来,像我这种 ...

  3. js在线题目

    在线题目: https://www.nowcoder.com/ta/js-assessment

  4. js小题目(持续更新)

    总是感觉之前做过的问题很久没碰的话就会忘掉,于是打算专门开一个记录小题目的随笔当题典用. 目录 五种主要数据类型进行值复制 数组去重 数组去重并计数 实现clone()方法,对五种主要数据类型进行值复 ...

  5. JS面试题目

    哪些地方会出现css阻塞,哪些地方会出现js阻塞? js的阻塞特性: 所有浏览器在下载JS的时候,会阻止一切其他活动,比如其他资源的下载,内容的呈现等等.直到JS下载.解析.执行完毕后才开始继续并行下 ...

  6. js 一道题目引发的正则的学习

    正则表达式中的特殊字符 字符 含意 \ 做为转意,即通常在"\"后面的字符不按原来意义解释,如/b/匹配字符"b",当b前面加了反斜杆后/\b/,转意为匹配一个 ...

  7. 2016年JS面试题目汇总

    1.怎样添加.移除.移动.复制.创建和查找节点? //1)创建新节点 createDocumentFragment() //创建一个DOM片段 createElement() //创建一个具体的元素 ...

  8. js一些题目

    假期在家,看到的,昨天看了下: 原文链接:http://wwwcqamin.duapp.com/?p=102#comment-7 请说出下面程序的输出结果 第一题: 1 2 3 4 5 6 7 8 9 ...

  9. js作用域题目

    window.number = 4var obj = { 'number': 4, 'tbl': (function(){ this.number *= 2; console.log(this.num ...

随机推荐

  1. framework7 总结之前遇到的问题和踩过的坑

    官网上写的案例比较简单明了,我这里就将我使用时踩过的坑做一个总结,与大家共勉! 最近使用framework,基本全靠浏览官方文档,当然,有遇到了许多的错误,开始不知道哪里出问题也很着急,到最后发现问题 ...

  2. java之maven之初识maven

    1.maven是一个项目管理工具. 包括项目创建.资源管理.项目运行.项目发布等功能. 2.为什么使用 maven? a. jar 依赖管理(升级.降级)等 b. 项目之间依赖管理 c. 资源文件管理 ...

  3. C#实现将字符串转换成代码并执行

    我们在写JavaScript程序的时候,有一个函数很有趣,eval(),这个方法非常有趣,他可以编译他内部的字符串,并将字符串按照JS代码执行,例如eval(‘alert(“message”)’),执 ...

  4. Git 分支的一些特殊的使用方式:Bug分支/feature分支/储存现场/

    参考链接:https://www.liaoxuefeng.com/wiki/896043488029600/900388704535136 一般都与dev分支进行合并 Bug分支 Bug分支也是一个分 ...

  5. python基础04day

    一 引子 数据类型 用途 定义方式 是否多项 有/无序 可/不可变 对应状态 数字     否 —— 不可   字符串    “”‘’“““””” 否 有 不可   列表    [] 是 有 可  同 ...

  6. ThinkCMF_X1.6.0-X2.2.3框架任意内容包含漏洞的简单分析复现(附自动化验证脚本)

    1.漏洞概述 攻击者可利用此漏洞构造恶意的url,向服务器写入任意内容的文件,达到远程代码执行的目的 2.影响版本 ThinkCMF X1.6.0 ThinkCMF X2.1.0 ThinkCMF X ...

  7. 个人推荐的Java邮件配置

    # 大部分host都是smtp.加上你邮箱@后面的域名spring.mail.host=smtp.localhost.com spring.mail.username= spring.mail.pas ...

  8. 开机没有deepin启动项的解决办法

    增加efi/deepin/grubx64.efi的启动项 问题描述 打开电脑,进入bios没有deepin启动项 解决办法 进入bios setup,选择boot sourquense,选择uefi, ...

  9. BitMap 图片格式与Base64Image格式互转方法

    BitMap 图片格式与Base64Image格式互转方法 /// <summary> /// 图片转为base64编码的字符串 /// </summary> /// < ...

  10. HDU4183 Pahom on Water(来回走最大流,一个点只经过一次)

    题意: 有n个圆,每个圆的中心和半径和一个频率都给定,只有一个频率最高的789为紫色,只有一个最低的400为红色,规则如下: 1.当两个圆严格相交时,且人是从红色到紫色的方向运动时可以由低频率向高频率 ...