10个棘手的用于面试的JavaScript代码段(1)

本文详细解释了JavaScript中的变量赋值规则、this关键字的行为、浮点数精度、超时和间隔、数组操作、严格相等性以及对象的使用。同时,作者分享了一份前端开发学习资源,旨在帮助读者系统学习和提升技能。
摘要由CSDN通过智能技术生成

代码段的输出不是shoaib和20,结果为undefined和26,这是由于JavaScript中的吊装而导致的。

我们再将上面的代码转换一下,如下:

var name = “shoaib”;

var age = 26

var info = function () {

var name;

console.log(name);

console.log(age);

name = 20;

};

info();

3、值分配

=========

function assign() {

var numOne = numTwo = 10;

}

assign();

console.log(‘numTwo’, typeof numTwo === ‘undefined’);

console.log(‘numOne’, typeof numOne === ‘undefined’);

输出

numTwo false

numOne true

同样,我们可以这样写:

function assign() {

var numOne= (numTwo = 10);

}

为什么?


赋值运算符具有从右到左的关联性,这意味着它将从右到左进行求值。这就是为什么numTwo要为其分配值10,然后将其分配给numOne的原因。

4、 JavaScript this

======================

var obj = {

name: “shoaib”,

func: function() {

var self = this;

console.log("outer function: this.name = " + this.name);

console.log("outer function: self.name = " + self.name);

(function() {

console.log("inner function: this.name = " + this.name);

console.log("inner function: self.name = " + self.name);

}());

}

};

obj.func();

输出

outer function: this.name = shoaib

outer function: self.name = shoaib

inner function: this.name = undefined

inner function: self.name = shoaib

为什么?


外部函数this和self引用obj,因此都可以正确访问该名称。但是内部部分不同。

在这里,this不参考obj。这就是为什么this.name是undefined。但是对局部变量的引用self仍在范围内,并且具有适当的访问权限。

5、JavaScript返回

==================

function funcOne() {

return {

name: “shoaib”,

};

}

function funcTwo() {

return;

{

name: “shoaib”;

}

}

console.log(funcOne());

console.log(funcTwo());

输出

{

name: ‘shoaib’

}

undefined

为什么?


此处,funcOne成功返回对象,但问题出在funcTwo。仔细看看:funcTwo后面有分号return。这意味着由于分号,这将不会返回任何内容。

6、数字.epsilon

================

console.log(0.1 + 0.2);

console.log(0.1 + 0.2 == 0.3);

输出

0.30000000000000004

false

为什么?

这是复杂的。结果可能是0.3且为true,但有可能不是。在JavaScript中,数字均以浮点精度处理,因此可能不会总是产生预期的结果。

解决办法是什么?

JavaScript为此引入了Math.abs。这将帮助你比较两个数字之间的绝对差。

function almostEqual(numOne, numTwo) {

return Math.abs( numOne - numTwo ) < Number.EPSILON;

}

console.log(almostEqual(0.1 + 0.2, 0.3));

7、超时和间隔时间

=============

(function() {

console.log(1);

setTimeout(function(){console.log(2)}, 1000);

setTimeout(function(){console.log(3)}, 0);

console.log(4);

})();

输出

1

4

3

2

为什么?

  • 第一和第四行控制台输出,没有任何延迟。

  • 然后在第三行,出现时间限制并执行日志。

  • 最后,十秒钟的延迟结束,并显示数字2。

8、反向数组

=============

var arrayOne = “shoaib”.split(‘’);

var arrayTwo = arrayOne.reverse();

var arrayThree = “mehedi”.split(‘’);

arrayTwo.push(arrayThree);

console.log(“arrayOne length=” + arrayOne.length + " value=" + arrayOne.slice(-1));

console.log(“arrayTwo length=” + arrayTwo.length + " value=" + arrayTwo.slice(-1));

输出

arrayOne length = 7 value = m,e,h,e,d,i

arrayTwo length = 7 value = m,e,h,e,d,i

为什么?

  • 在JavaScript中使用reverse时,该方法不仅会返回reversed数组。它还会颠倒数组本身的顺序。

  • reverse方法返回对数组本身的引用。

为了更好地理解,下面是一个示例:

const array1 = [‘one’, ‘two’, ‘three’];

console.log(‘array1:’, array1);

// expected output: “array1:” Array [“one”, “two”, “three”]

const reversed = array1.reverse();

console.log(‘reversed:’, reversed);

// expected output: “reversed:” Array [“three”, “two”, “one”]

// Careful: reverse is destructive – it changes the original array.

console.log(‘array1:’, array1);

// expected output: “array1:” Array [“three”, “two”, “one”]

9、严格平等

==========

console.log(false == ‘0’)

console.log(false === ‘0’)

输出

true

false

为什么?

在JavaScript中,在两件事之间进行比较,这并不严格。如果要严格比较,则可以使用=而不是==进行比较,这将比较两件事及其数据类型。同样,!=和!==运算符也可以这样工作。

10、JavaScript对象

======================

var person = {

name: ‘shoaib’,

identity: function (){

return this.name;

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

今天的文章可谓是积蓄了我这几年来的应聘和面试经历总结出来的经验,干货满满呀!如果你能够一直坚持看到这儿,那么首先我还是十分佩服你的毅力的。不过光是看完而不去付出行动,或者直接进入你的收藏夹里吃灰,那么我写这篇文章就没多大意义了。所以看完之后,还是多多行动起来吧!

可以非常负责地说,如果你能够坚持把我上面列举的内容都一个不拉地看完并且全部消化为自己的知识的话,那么你就至少已经达到了中级开发工程师以上的水平,进入大厂技术这块是基本没有什么问题的了。

[外链图片转存中…(img-TzimWiUP-1713425932339)]

[外链图片转存中…(img-B1PB3Yk1-1713425932339)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

[外链图片转存中…(img-M4lj181f-1713425932340)]

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

[外链图片转存中…(img-tGktTAY9-1713425932340)]

最后

今天的文章可谓是积蓄了我这几年来的应聘和面试经历总结出来的经验,干货满满呀!如果你能够一直坚持看到这儿,那么首先我还是十分佩服你的毅力的。不过光是看完而不去付出行动,或者直接进入你的收藏夹里吃灰,那么我写这篇文章就没多大意义了。所以看完之后,还是多多行动起来吧!

可以非常负责地说,如果你能够坚持把我上面列举的内容都一个不拉地看完并且全部消化为自己的知识的话,那么你就至少已经达到了中级开发工程师以上的水平,进入大厂技术这块是基本没有什么问题的了。

资料领取方式:戳这里前往免费领取

  • 27
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值