10个棘手的用于面试的JavaScript代码段,CSS的行内样式与内联样式

本文详细解释了JavaScript中的变量作用域、函数调用、this关键字、返回值类型、严格相等比较、浮点数精度、超时和间隔、数组操作以及JavaScript中的基础概念,如执行上下文、作用域链和原型链,帮助理解JavaScript语言的特性和常见陷阱。
摘要由CSDN通过智能技术生成

预测以下代码的输出:

var name = “shoaib”;

var age = 26

var info = function () {

console.log(name);

console.log(age);

var name = 20;

};

info();

输出

undefined

26

为什么?


代码段的输出不是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、严格平等

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

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

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

img

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

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

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

完整版面试题资料免费分享,只需你点赞支持,动动手指点击此处就可免费领取了

前端实习面试的套路


回顾项目

往往在面试时,面试官根据你简历中的项目由点及面地展开问答,所以请对你做过的最好的项目进行回顾和反思。回顾你做过的工作和项目中最复杂的部分,反思你是如何完成这个最复杂的部分的。

面试官会重点问你最复杂的部分的实现方法和如何优化。重点要思考如何优化,即使你项目中没有对那部分进行优化,你也应该预先思考有什么优化的方案。如果这部分答好了,会给面试官留下很不错的印象。

重点在于基础知识

这里指的基础知识包括:前端基础知识和学科基础知识。

前端基础知识:html/css/js 的核心知识,其中 js 的核心知识尤为重要。比如执行上下文、变量对象/活动对象(VO/AO)、作用域链、this 指向、原型链等。

学科基础知识:数据结构、计算机网络、算法等知识。你可能会想前端不需要算法,那你可能就错了,在大公司面试,面试官同样会看重学生这些学科基础知识。
你可能发现了我没有提到React/Vue这些框架的知识,这里得说一说,大公司不会过度的关注这方面框架的知识,他们往往更加考察学生的基础。
这里我的建议是,如果你至少使用或掌握其中一门框架,那是最好的,可以去刷刷相关框架的面试题,这样在面试过程中即使被问到了,也可以回答个 7788。如果你没有使用过框架,那也不需要太担心,把重点放在基础知识和学科基础知识之上,有其余精力的话可以去看看主流框架的核心思想。

顾项目**

往往在面试时,面试官根据你简历中的项目由点及面地展开问答,所以请对你做过的最好的项目进行回顾和反思。回顾你做过的工作和项目中最复杂的部分,反思你是如何完成这个最复杂的部分的。

面试官会重点问你最复杂的部分的实现方法和如何优化。重点要思考如何优化,即使你项目中没有对那部分进行优化,你也应该预先思考有什么优化的方案。如果这部分答好了,会给面试官留下很不错的印象。

重点在于基础知识

这里指的基础知识包括:前端基础知识和学科基础知识。

前端基础知识:html/css/js 的核心知识,其中 js 的核心知识尤为重要。比如执行上下文、变量对象/活动对象(VO/AO)、作用域链、this 指向、原型链等。

学科基础知识:数据结构、计算机网络、算法等知识。你可能会想前端不需要算法,那你可能就错了,在大公司面试,面试官同样会看重学生这些学科基础知识。
你可能发现了我没有提到React/Vue这些框架的知识,这里得说一说,大公司不会过度的关注这方面框架的知识,他们往往更加考察学生的基础。
这里我的建议是,如果你至少使用或掌握其中一门框架,那是最好的,可以去刷刷相关框架的面试题,这样在面试过程中即使被问到了,也可以回答个 7788。如果你没有使用过框架,那也不需要太担心,把重点放在基础知识和学科基础知识之上,有其余精力的话可以去看看主流框架的核心思想。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值