大挑战! JS前端知识闯关,你过得了几关?

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介: 基础知识真有趣,10个基础知识的题目,请君来战!

1.JPG


前言



基础知识真有趣,10个基础知识的题目,请君来战!


1. a.x = a = {n:2}



var a = {n:1};
a.x = a = {n:2};
// 求a.x
alert(a.x); 
复制代码


解析


JavaScript 总是严格按照从左至右的顺序来计算表达式。


a.x 最后执行赋值的时候,保留的是对 原来a的引用, alert的时候,a是被重新赋值过后的a。


var a = {n:1}, ref = a;
a.x = a = {n:2};
console.log("a:", a); 
console.log("ref:",ref);
复制代码

2.JPG


2. 按位或取整数部分


求值:

100.8 | 0   
-101.6 | 0   
8589934592.8 | 0
复制代码


解析


位运算符将数字视为32位的有符号整数,而32位整数的取值范围是 -2147483648 ~ 2147483647

超过32位有符号整数范围取值的数,进行位或操作取整都是不准确的。


2147483647.1 | 0  //  2147483647 正确
 2147483648.1 | 0  // -2147483648 错误
-2147483648.1 | 0  // -2147483648 正确
-2147483649.1 | 0  //  2147483647 错误
复制代码


同样的,我们可以用~~来取整数部分, 当然依旧存在超范围就不准确的问题。


~~ 100.8 // 100  正确
~~ 2147483649.1  // -2147483647  错误
复制代码


答案


100.8 | 0    // 100
-101.6 | 0   // -101
8589934592.8 | 0  // 0
复制代码


3. 神奇的eval


var x = "global";
function log1(){
    var x = "local";
    return eval("x")
}
function log2(){
    var x = "local";
    return window.eval("x")
}
function log3(){
    var x = "local";
    var fn = eval
    return fn("x")
}
function log4(){
    var x = "local";
    return (0, eval)("x")
}
log1();
log2();
log3();
log4();
复制代码


解析


eval函数具备访问调用它那是的整个作用域的能力。


间接调用, 例如绑定eval函数到另外一个变量名,通过变量名调用函数会使代码失去去所有局部作用域访问的能力。


(0, eval) 其也是eval的间接调用。


log1();   // local
log2();   // global
log3();   // global
log4();   // global
复制代码


答案


4. delete知多少



delete null;
delete undefined;
复制代码


解析


undefined在实现上是一个全局属性, 而null是一个关键字。


Oject.getOwnPropertyDescriptor(global, 'undefined')
复制代码
复制代码

2.JPG


null在全局上却查询不到描述信息:


Object.getOwnPropertyDescriptor(global, 'null')
复制代码
复制代码

3.JPG


结果


delete null; // true
delete undefined; // false
复制代码


5. 类型转换



function Person(name, age) {
    this.name = name;
    this.age = age;
}
Person.prototype.valueOf = function () {
    return this.age;
}
Person.prototype.toString = function () {
    return this.name
}
Date.prototype.valueOf = function () {
    return this.getTime()
}
Date.prototype.toString = function () {
    return this.getTime() + ""
}
var person = new Person("tom", 100);
console.log(person + 10);
console.log(`${person}`)
console.log("" + person)
var date = new Date(2001, 0, 0);
console.log(date + 0, typeof (date + 0))
console.log(date + date.getTime());
复制代码


分析


对象转换成基础数据类型


  • Symbol.toPrimitive 优先
  • 如果预期转为字符串,Object.prototype.toString
  • 如果无预期转为字符串, 先走 Oject.prototye.valueOf, 再走Object.prototype.toString, 特例是Date类型,是先toString,再valueOf


注意两点


  1. 预期转为字符串这种字样, 比如 `${person}`
  2. Date是特别的,是优先toString


结果


var person = new Person("tom", 100); 
console.log(person + 10);  // 110
console.log(`${person}`)   // tom
console.log("" + person)   // 100
var date = new Date(2001, 0, 0);
console.log(date + 0, typeof (date + 0)) 
// 9781920000000 string
console.log(date + date.getTime());
// 978192000000978192000000
复制代码


6. 函数的length



function add(num1, num2, num3=1, ...args){ 
}
const boundAdd = add.bind(null, 10);
console.log(boundAdd.length)
复制代码


问题解析


  1. 有默认值的参数,不计入长度
  2. 剩余参数不计入长度
  3. bind之后,减少对应的length长度


答案


console.log(boundAdd.length) // 1
复制代码


7. this的指向


var value = 1;
var foo = {
  value: 2,
  bar: function () {
    return this.value;
  }
}
console.log(foo.bar());
console.log((foo.bar)());
console.log((foo.bar = foo.bar)());
console.log((false || foo.bar)());
console.log((foo.bar, foo.bar)());
复制代码


解析


ES规范中,引用类型(Reference类型)有一个获取对应值的方法: GetValue。 简单模拟 GetValue 的使用:


var foo = 1;
var fooReference = {
    base: EnvironmentRecord,
    name: 'foo',
    strict: false
};
GetValue(fooReference) // 1;
复制代码


GetValue 返回对象属性真正的值,但是要注意: 调用 GetValue,返回的将是具体的值,而不再是一个 Reference


本题目如果调用了 GetValue, 那么其作用域就变成了全局。


(foo.bar) 并没有调用取值操作,而其余的均调用了取值操作。


更多详情: JavaScript深入之从ECMAScript规范解读this


答案


console.log(foo.bar());   // 2
console.log((foo.bar)());  // 2
console.log((foo.bar = foo.bar)());  // 1
console.log((false || foo.bar)());   // 1
console.log((foo.bar, foo.bar)());   // 1
复制代码


8.参数传递


function test(param1, param2, param3) {
    param1 = "new param1";
    param3  = "new param3"
    console.log(param1 == arguments[0]);
    console.log(param3 == arguments[2]);
}
function test_strict(param1, param2, param3) {
    "use strict"
    param1 = "new param1";
    param3  = "new param3"
    console.log(param1 == arguments[0]);
    console.log(param3 == arguments[2]);
}
test('param1', 'param2')
test_strict('param1', 'param2');
复制代码


解析


非严格模式下:传入的参数,实参和 arguments 的值会共享,当没有传入时,实参与 arguments 值不会共享。


严格模式下,实参和 arguments 是不会共享的。


答案


test('param1', 'param2')
test_strict('param1', 'param2');
// true
// false
// false
// false
复制代码


9. 小数相加



(0.1 + 0.2) + 0.3  === 0.1 + (0.2 + 0.3)
复制代码


解析


简略的回答就是精确问题。


更多的回答 IEEE 754, 双精度浮点数(64位),使用1为符号位、11位指数位、52位尾数位来表示。



借助:www.binaryconvert.com/result_doub…

0.1 0-01111111011-1001100110011001100110011001100110011001100110011010
0.2 0-01111111100-1001100110011001100110011001100110011001100110011010
0.3 0-01111111101-0011001100110011001100110011001100110011001100110011
复制代码


当然,计算还好好几个步骤

  • 对阶(大阶对小阶)
  • 位数运算
  • 结果规格化
  • 舍入处理
  • 移除检查


当然,本题,后面两项都不存在。 具体细节,改篇文章再见!


答案


(0.1 + 0.2) + 0.3  === 0.1 + 0.2 + 0.3  // false
0.6000000000000001 === 0.6 // false
复制代码


10. 自动补全



如下代码输出的值


var a = [[1,2],2,3]
console.log(a)
[0,2,3].map(v=> console.log(v*v))
console.log(a)
复制代码


解析


javascript能智能的插入分号,但是有5个有问题的字符需要密切的注意: (,[, +, -, /, 其作为一行代码的开头,很可能产生意外的情况,所以,没事代码最后写个分号,保准没错。


答案


4.JPG


写在最后



技术交流群请到 这里来。 或者添加我的微信 dirge-cloud,带带我,一起学习。

相关文章
|
7天前
|
前端开发 JavaScript
前端ES5 | js —添加元素方法
前端ES5 | js —添加元素方法
|
8天前
|
JavaScript 前端开发
前端JS函数
【9月更文挑战第4天】前端JS函数
19 6
|
11天前
|
开发者 图形学 开发工具
Unity编辑器神级扩展攻略:从批量操作到定制Inspector界面,手把手教你编写高效开发工具,解锁编辑器隐藏潜能
【8月更文挑战第31天】Unity是一款强大的游戏开发引擎,支持多平台发布与高度可定制的编辑器环境。通过自定义编辑器工具,开发者能显著提升工作效率。本文介绍如何使用C#脚本扩展Unity编辑器功能,包括批量调整游戏对象位置、创建自定义Inspector界面及项目统计窗口等实用工具,并提供具体示例代码。理解并应用这些技巧,可大幅优化开发流程,提高生产力。
38 1
|
11天前
|
开发者 图形学 C#
深度解密:Unity游戏开发中的动画艺术——Mecanim状态机如何让游戏角色栩栩如生:从基础设置到高级状态切换的全面指南,助你打造流畅自然的游戏动画体验
【8月更文挑战第31天】Unity动画系统是游戏开发的关键部分,尤其适用于复杂角色动画。本文通过具体案例讲解Mecanim动画状态机的使用方法及原理。我们创建一个游戏角色并设计行走、奔跑和攻击动画,详细介绍动画状态机设置及脚本控制。首先导入动画资源并添加Animator组件,然后创建Animator Controller并设置状态间的转换条件。通过编写C#脚本(如PlayerMovement)控制动画状态切换,实现基于玩家输入的动画过渡。此方法不仅适用于游戏角色,还可用于任何需动态动画响应的对象,增强游戏的真实感与互动性。
31 0
|
11天前
|
Android开发 iOS开发 C#
Xamarin:用C#打造跨平台移动应用的终极利器——从零开始构建你的第一个iOS与Android通用App,体验前所未有的高效与便捷开发之旅
【8月更文挑战第31天】Xamarin 是一个强大的框架,允许开发者使用单一的 C# 代码库构建高性能的原生移动应用,支持 iOS、Android 和 Windows 平台。作为微软的一部分,Xamarin 充分利用了 .NET 框架的强大功能,提供了丰富的 API 和工具集,简化了跨平台移动应用开发。本文通过一个简单的示例应用介绍了如何使用 Xamarin.Forms 快速创建跨平台应用,包括设置开发环境、定义用户界面和实现按钮点击事件处理逻辑。这个示例展示了 Xamarin.Forms 的基本功能,帮助开发者提高开发效率并实现一致的用户体验。
23 0
|
11天前
|
开发者 C# Android开发
明白吗?Xamarin与Native的终极对决:究竟哪种开发方式更适合您的项目需求,让我们一探究竟!
【8月更文挑战第31天】随着移动应用开发的普及,开发者面临多种技术选择。本文对比了跨平台解决方案Xamarin与原生开发方式的优势与劣势。Xamarin使用C#进行跨平台开发,代码复用率高,可大幅降低开发成本;但因基于抽象层,可能影响性能。原生开发则充分利用平台特性,提供最佳用户体验,但需维护多套代码库,增加工作量。开发者应根据项目需求、团队技能和预算综合考量,选择最适合的开发方式。
54 0
|
11天前
|
开发者 Android开发 iOS开发
Xamarin开发者的神器!揭秘你绝不能错过的插件和工具,让你的开发效率飞跃式提升
【8月更文挑战第31天】Xamarin.Forms 是一个强大的框架,让开发者通过单一共享代码库构建跨平台移动应用,支持 iOS、Android 和 Windows。使用 C# 和 XAML,它简化了多平台开发流程,保持一致的用户体验。本指南通过创建一个简单的 “HelloXamarin” 应用介绍 Xamarin.Forms 的基本功能和工作原理。首先配置 Visual Studio 开发环境,然后创建并运行一个包含标题、按钮和消息标签的示例应用,展示如何定义界面布局及处理按钮点击事件。这帮助开发者快速入门 Xamarin.Forms,提高跨平台应用开发效率。
27 0
|
11天前
|
前端开发 Java UED
JSF 面向组件开发究竟藏着何种奥秘?带你探寻可复用 UI 组件设计的神秘之路
【8月更文挑战第31天】在现代软件开发中,高效与可维护性至关重要。JavaServer Faces(JSF)框架通过其面向组件的开发模式,提供了构建复杂用户界面的强大工具,特别适用于设计可复用的 UI 组件。通过合理设计组件的功能与外观,可以显著提高开发效率并降低维护成本。本文以一个具体的 `MessageComponent` 示例展示了如何创建可复用的 JSF 组件,并介绍了如何在 JSF 页面中使用这些组件。结合其他技术如 PrimeFaces 和 Bootstrap,可以进一步丰富组件库,提升用户体验。
21 0
|
11天前
|
Java 开发者 关系型数据库
JSF与AWS的神秘之旅:如何在云端部署JSF应用,让你的Web应用如虎添翼?
【8月更文挑战第31天】在云计算蓬勃发展的今天,AWS已成为企业级应用的首选平台。本文探讨了在AWS上部署JSF(JavaServer Faces)应用的方法,这是一种广泛使用的Java Web框架。通过了解并利用AWS的基础设施与服务,如EC2、RDS 和 S3,开发者能够高效地部署和管理JSF应用。文章还提供了具体的部署步骤示例,并讨论了使用AWS可能遇到的挑战及应对策略,帮助开发者更好地利用AWS的强大功能,提升Web应用开发效率。
36 0
|
11天前
|
API UED 开发者
如何在Uno Platform中轻松实现流畅动画效果——从基础到优化,全方位打造用户友好的动态交互体验!
【8月更文挑战第31天】在开发跨平台应用时,确保用户界面流畅且具吸引力至关重要。Uno Platform 作为多端统一的开发框架,不仅支持跨系统应用开发,还能通过优化实现流畅动画,增强用户体验。本文探讨了Uno Platform中实现流畅动画的多个方面,包括动画基础、性能优化、实践技巧及问题排查,帮助开发者掌握具体优化策略,提升应用质量与用户满意度。通过合理利用故事板、减少布局复杂性、使用硬件加速等技术,结合异步方法与预设缓存技巧,开发者能够创建美观且流畅的动画效果。
34 0