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%以上前端开发知识点,真正体系化!

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

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

最后

一个好的心态和一个坚持的心很重要,很多冲着高薪的人想学习前端,但是能学到最后的没有几个,遇到困难就放弃了,这种人到处都是,就是因为有的东西难,所以他的回报才很大,我们评判一个前端开发者是什么水平,就是他解决问题的能力有多强。

分享一些简单的前端面试题以及学习路线给大家,狂戳这里即可免费领取

8970)]

[外链图片转存中…(img-XaixSwvK-1712073278970)]

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

[外链图片转存中…(img-KkLLVJ8P-1712073278971)]

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

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

最后

一个好的心态和一个坚持的心很重要,很多冲着高薪的人想学习前端,但是能学到最后的没有几个,遇到困难就放弃了,这种人到处都是,就是因为有的东西难,所以他的回报才很大,我们评判一个前端开发者是什么水平,就是他解决问题的能力有多强。

分享一些简单的前端面试题以及学习路线给大家,狂戳这里即可免费领取

[外链图片转存中…(img-xgvCpfzM-1712073278971)]

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值