JS面试题汇总(六)

news/2024/7/10 23:45:27 标签: javascript, es6, 前端, js, 面试

📒博客首页:酸狗的博客🍋
🎉欢迎关注🔎点赞👍收藏⭐️留言📝
💖热爱前端学习,期待一起交流!✨
🙏作者水平很有限,如果发现错误,求告知,多谢!🌈
😎有问题可私信我交流🙄

🧲往期点这里:↓⚡
JS面试题汇总(一)
JS面试题汇总(二)
JS面试题汇总(三)
JS面试题汇总(四)
JS面试题汇总(五)
51. 移动端的点击事件的有延迟,时间是多久,为什么会有? 怎么解决这个延时?

参考答案:

1. 300 毫秒
2. 因为浏览器捕获第一次单击后,会先等待一段时间,如果在这段时间区间里用户未进行下一次点击,则浏览器会做单击事件的处理。如果这段时间里用户进行了第二次单击操作,则浏览器会做双击事件处理。
3. 推荐 fastclick.js

52. 解释 JavaScript 中的作用域与变量声明提升?

参考答案:

  • 我对作用域的理解是只会对某个范围产生作用,而不会对外产生影响的封闭空间。在这样的一些空间里,外部不能访问内部变量,但内部可以访问外部变量。
  • 所有申明都会被提升到作用域的最顶上
  • 同一个变量申明只进行一次,并且因此其他申明都会被忽略
  • 函数声明的优先级优于变量申明,且函数声明会连带定义一起被提升

53. Node.js 的适用场景?

参考答案:比如:RESTFUL API、实时聊天、客户端逻辑强大的单页 APP,具体的例子比如说:本地化的在线音乐应用,本地化的在线搜索应用,本地化的在线 APP 等。

解析:参考

54. bind、call、apply 的区别

参考答案:

call 和 apply 其实是一样的,区别就在于传参时参数是一个一个传或者是以一个数组的方式来传。

call 和 apply 都是在调用时生效,改变调用者的 this 指向。


let name = 'Jack'
const obj = {name: 'Tom'}
function sayHi() {console.log('Hi! ' + this.name)}

sayHi() // Hi! Jack
sayHi.call(obj) // Hi! Tom

bind 也是改变 this 指向,不过不是在调用时生效,而是返回一个新函数。


const newFunc = sayHi.bind(obj)
newFunc() // Hi! Tom

55. 使用构造函数的注意点

参考答案:

1. 一般情况下构造函数的首字母需要大写,因为我们在看到一个函数首字母大写的情况,就认定这是一个构造函数,需要跟new关键字进行搭配使用,创建一个新的实例(对象)
2. 构造函数在被调用的时候需要跟new关键字搭配使用。
3. 在构造函数内部通过this+属性名的形式为实例添加一些属性和方法。
4. 构造函数一般不需要返回值,如果有返回值

- 4.1 如果返回值是一个基本数据类型,那么调用构造函数,返回值仍旧是那么创建出来的对象。
- 4.2 如果返回值是一个复杂数据类型,那么调用构造函数的时候,返回值就是这个return之后的那个复杂数据类型。

56. 如何获取浏览器版本信息

参考答案:

window. navigator. userAgent

57. 如何实现文件断点续传

参考答案:

断点续传最核心的内容就是把文件“切片”然后再一片一片的传给服务器,但是这看似简单的上传过程却有着无数的坑。

首先是文件的识别,一个文件被分成了若干份之后如何告诉服务器你切了多少块,以及最终服务器应该如何把你上传上去的文件进行合并,这都是要考虑的。

因此在文件开始上传之前,我们和服务器要有一个“握手”的过程,告诉服务器文件信息,然后和服务器约定切片的大小,当和服务器达成共识之后就可以开始后续的文件传输了。

前台要把每一块的文件传给后台,成功之后前端和后端都要标识一下,以便后续的断点。

当文件传输中断之后用户再次选择文件就可以通过标识来判断文件是否已经上传了一部分,如果是的话,那么我们可以接着上次的进度继续传文件,以达到续传的功能。
有了 HTML5 的 File api 之后切割文件比想想的要简单的多的多。

只要用 slice 方法就可以了

js">var packet = file.slice(start, end);

参数 start 是开始切片的位置,end 是切片结束的位置 单位都是字节。通过控制 start 和 end 就可以是实现文件的分块

js">file.slice(0,1000);
file.slice(1000,2000);
file.slice(2000,3000);
// ......

在把文件切成片之后,接下来要做的事情就是把这些碎片传到服务器上。
如果中间掉线了,下次再传的时候就得先从服务器获取上一次上传文件的位置,然后以这个位置开始上传接下来的文件内容。

解析:参考

58. 数组的常用方法

参考答案:

1. Array. map()

此方法是将数组中的每个元素调用一个提供的函数,结果作为一个新的数组返回,并没有改变原来的数组

js">let arr = [1, 2, 3, 4, 5];
let newArr = arr.map(x => x * 2);
//arr= [1, 2, 3, 4, 5]   原数组保持不变
//newArr = [2, 4, 6, 8, 10] 返回新数组

2. Array. forEach()

此方法是将数组中的每个元素执行传进提供的函数,没有返回值,直接改变原数组,注意和 map 方法区分

js">let arr = [1, 2, 3, 4, 5];
num.forEach(x => x * 2);
// arr = [2, 4, 6, 8, 10]  数组改变,注意和map区分

3. Array. filter()

此方法是将所有元素进行判断,将满足条件的元素作为一个新的数组返回

js">let arr = [1, 2, 3, 4, 5]
const isBigEnough => value => value >= 3
let newArr = arr.filter(isBigEnough)
//newNum = [3, 4, 5] 满足条件的元素返回为一个新的数组

4. Array. every()

此方法是将所有元素进行判断返回一个布尔值,如果所有元素都满足判断条件,则返回 true,否则为 false:

js">let arr = [1, 2, 3, 4, 5]
const isLessThan4 => value => value < 4
const isLessThan6 => value => value < 6
arr.every(isLessThan4) //false
arr.every(isLessThan6) //true

5. Array. some()

此方法是将所有元素进行判断返回一个布尔值,如果存在元素都满足判断条件,则返回 true,若所有元素都不满足判断条件,则返回 false:

js">let arr = [1, 2, 3, 4, 5]
const isLessThan4 => value => value < 4
const isLessThan6 => value => value > 6
arr.some(isLessThan4) //true
arr.some(isLessThan6) //false

6. Array. reduce()

此方法是所有元素调用返回函数,返回值为最后结果, 传入的值必须是函数类型:

js">let arr = [1, 2, 3, 4, 5];
const add = (a, b) => a + b;
let sum = arr.reduce(add);
//sum = 15  相当于累加的效果

与之相对应的还有一个 Array. reduceRight() 方法,区别是这个是从右向左操作的

7. Array. push()

此方法是在数组的后面添加新加元素,此方法改变了数组的长度:

javascript">let arr = [1, 2, 3, 4];
arr.push(5);
console.log(arr); //[1, 2, 3, 4, 5]
console.log(arr.length); //5

8. Array. pop()

此方法在数组后面删除最后一个元素,并返回数组,此方法改变了数组的长度:

js">let arr = [1, 2, 3, 4, 5];
arr.pop();
console.log(arr); //[1, 2, 3, 4]
console.log(arr.length); //4

9. Array. shift()

此方法在数组后面删除第一个元素,并返回数组,此方法改变了数组的长度:

js">let arr = [1, 2, 3, 4, 5];
arr.shift();
console.log(arr); //[2, 3, 4, 5]
console.log(arr.length); //4
  1. Array.unshift()

此方法是将一个或多个元素添加到数组的开头,并返回新数组的长度:

js">let arr = [1, 2, 3, 4, 5];
arr.unshift(6, 7);
console.log(arr); //[6, 7, 2, 3, 4, 5]
console.log(arr.length); //7
  1. Array.isArray()

判断一个对象是不是数组,返回的是布尔值:

javascript">Array.isArray([1, 2, 3, 4]);  // --> true
 
var obj = {
    a: 1,
    b: 2
};
Array.isArray(obj);  // --> false
 
Array.isArray(new Array);  // --> true
 
Array.isArray("Array");  // --> false
  1. Array.concat()

此方法是一个可以将多个数组拼接成一个数组:

javascript">let arr1 = [1, 2, 3]
arr2 = [4, 5]
let arr = arr1.concat(arr2)
console.log(arr) //[1, 2, 3, 4, 5]
  1. Array.toString()

此方法将数组转化为字符串:

javascript">let arr = [1, 2, 3, 4, 5];
let str = arr.toString()
console.log(str) // 1,2,3,4,5
  1. Array.join()

此方法也是将数组转化为字符串:

js">let arr = [1, 2, 3, 4, 5];
let str1 = arr.toString()
let str2 = arr.toString(',')
let str3 = arr.toString('##')
console.log(str1) // 12345
console.log(str2) // 1,2,3,4,5
console.log(str3) // 1##2##3##4##5

通过例子可以看出和 toString 的区别,可以设置元素之间的间隔~

  1. Array.splice(开始位置, 删除的个数,元素)

万能方法,可以实现增删改:

js">let arr = [1, 2, 3, 4, 5];
let arr1 = arr.splice(2, 0 'haha')
let arr2 = arr.splice(2, 3)
let arr1 = arr.splice(2, 1 'haha')
console.log(arr1) //[1, 2, 'haha', 3, 4, 5]新增一个元素
console.log(arr2) //[1, 2] 删除三个元素
console.log(arr3) //[1, 2, 'haha', 4, 5] 替换一个元素

59. 字符串常用操作

参考答案:

  • charAt(index): 返回指定索引处的字符串
  • charCodeAt(index): 返回指定索引处的字符的 Unicode 的值
  • concat(str1, str2, … ): 连接多个字符串,返回连接后的字符串的副本
  • fromCharCode(): 将 Unicode 值转换成实际的字符串
  • indexOf(str): 返回 str 在父串中第一次出现的位置,若没有则返回-1
  • lastIndexOf(str): 返回 str 在父串中最后一次出现的位置,若没有则返回-1
  • match(regex): 搜索字符串,并返回正则表达式的所有匹配
  • replace(str1, str2):str1 也可以为正则表达式,用 str2 替换 str1
  • search(regex): 基于正则表达式搜索字符串,并返回第一个匹配的位置
  • slice(start, end):返回字符索引在 start 和 end(不含)之间的子串
  • split(sep,limit):将字符串分割为字符数组,limit 为从头开始执行分割的最大数量
  • substr(start,length):从字符索引 start 的位置开始,返回长度为 length 的子串
  • substring(from, to):返回字符索引在 from 和 to(不含)之间的子串
  • toLowerCase():将字符串转换为小写
  • toUpperCase():将字符串转换为大写
  • valueOf():返回原始字符串值

60. 作用域的概念及作用

参考答案:

  • 作用域 : 起作用的一块区域
  • 作用域的概念: 对变量起保护作用的一块区域
  • 作用: 作用域外部无法获取到作用域内部声明的变量,作用域内部能够获取到作用域外界声明的变量。

http://www.niftyadmin.cn/n/805952.html

相关文章

Android-IM架构设计

###1. 架构总览 ###2. 模块介绍 ####2.1 协议封装与任务流程 #####1) 协议与任务的封装 a. 协议有协议头(协议头因为格式相同&#xff0c;被抽象出来)和协议体组成&#xff0c;协议有两类&#xff1a;请求协议(request)和回复协议(response)&#xff1b;b. 任务(action)由请求协…

Cygwin中vi编辑器方向键和Backspace键不好使的解决方法

cd ~touch .virc修改.virc文件&#xff08;如果没有就创建&#xff09;vi .virc添加以下内容set nocpset backspacestart,indent,eol保存退出:wq如果是vim就修改.vimrc文件。 转&#xff1a;http://blog.chinaunix.net/xmlrpc.php?rblog/article&uid26669282&id406836…

家用电脑何去何从 (转)

家用电脑何去何从 (转)[more]家用电脑何去何从新华网 (2001.02.16 16:01:20)新华网消息 &#xff12;&#xff10;&#xff10;&#xff10;年中国个人电脑市场在互联网应用的推动下保持了高速增长。今后的家用电脑市场将会出现哪些变化呢&#xff1f;笔者为此请教了业内专家&…

【线程池源码系列】ThreadPoolExecutor 源码解析(下)

Woker worker 就是工作线程的 Runnable 参数对象&#xff0c;线程启动后会调用其 run() // 继承 AQS 主要是为了方便线程的中断处理&#xff0c;即不是为了防止有多个线程来争抢什么资源&#xff0c; // 而是因为&#xff0c;如果当前线程在 getTask() 获取到 task &#xff…

这种体验,尴尬了!游戏设计师面临的窘境!(文末送书)

《体验传递》作者&#xff1a;路行己&#xff0c;文末送出四本关于作者路行己&#xff0c;游戏用户体验设计师、中国传媒大学客座讲师。从业十余年&#xff0c;曾在FunPlus、CD PROJEKT RED、盖娅互娱、玩蟹科技等多家知名游戏公司从事用户体验相关工作&#xff0c;现任华清飞扬…

Jsp将后端new Date格式转换后显示到前端界面

<fmt:formatDatevalue"${time}" type"date"pattern"yyyy-MM-dd HH:mm"/>

JS面试题汇总(七)

&#x1f4d2;博客首页&#xff1a;酸狗的博客&#x1f34b; &#x1f389;欢迎关注&#x1f50e;点赞&#x1f44d;收藏⭐️留言&#x1f4dd; &#x1f496;热爱前端学习&#xff0c;期待一起交流&#xff01;✨ &#x1f64f;作者水平很有限&#xff0c;如果发现错误&#x…

微软表示 Open Source 运动反而压抑了创新 (转)

微软表示 Open Source 运动反而压抑了创新 (转)[more] 这件事肯定引起相当的质疑&#xff0c;起因於微软的操作系统部门执行长 - Jim Allchin 表示现在到处散布的软件程序码 - 例如 Linux 这个操作系统的竞争者&#xff0c;将会扼 杀了软件开发的创意&#xff0c;而那些立法官…