-
自我介绍
-
对前端了解知识,怎么解除前端
-
js,红宝书,包括什么内容
-
闭包,为什么会有闭包
-
样式污染
-
发布订阅者模式(具体过程):a发送消息给b.c.d
-
跨站请求伪造(CSRF),怎么拿到cookies的?
-
设计模式(列举)
-
排序算法中最快的是:快排;快排的时间复杂度nlogn,怎么算出来的?
-
动态规划
-
前端偶像,做出的前端探索
-
最有成就感的事,风场粒子,最难的一点在于哪一步
-
数据库,事务,视图
为什么会有闭包:在js里,函数是一等公民,函数可以作为函数的返回值,也可以作为函数的参数传入,那么在函数调用时会出现funarg 问题,打破了基于栈的内存分配模式。为了解决这个问题,不得不引入闭包机制来解决这funarg问题。
function f1() {
var n = 999;
function f2() {
alert(n);
}
return f2;
}
var result = f1();
result(); // 999
执行上下文可以理解为函数执行的环境,每一个函数执行时,都会给对应的函数创建这样一个执行环境。
首先全局作用域入栈,在遇到result=f1()时,开始调用f1(),f1()入栈,执行f1()中的代码,然后虽然f2()在f1()中,但是并没有被调用所以不会产生新的执行环境,等到f1()执行完了出栈,返回f2,然后赋值给result,下面的result()(就是调用result函数,如果这时候还没有被调用,那他被保存在堆中)其实就是f2(),这时产生新的执行环境,有了入栈和出栈这些动作,
二、
1、foreach中awiat为什么不能用 ,forof可以:forEach是直接调用回调函数,for...of 是通过迭代器的方式去遍历的。
用await:callback
其实是我们传入的一个被 async 封装的 promise 对象,而 Array.prototype.forEach 内部并未对这个promise 对象做任何处理,只是忽略它。
/*
O 为传入数组
len 为传入数组长度
callback 为传入回调函数
*/
while (k < len) {
var kValue;
if (k in O) {
kValue = O[k];
callback.call(T, kValue, k, O);
}
k++;
}
2、flex布局、水平垂直居中、margin设置宽高,而flex不用
flex两侧固定,中间自适应,而margin是需要自己设置宽高
3、十万加文本单词,找频率最高的十个单词:先用hashmap存值和出现的频率,在对频率进行排序。堆排序(对于大数据),小顶堆(因为是降序)。
4、论文、项目难点
三、
1、XSS(跨站请求伪造)特殊转义字符: <>
2、判断是否是数组的几种方式
3、promise的all,数组中三个树,其中两个正常,一个会报错,怎么让正常的两个返回
由于
Promise.all(request).then(…).catch(…)
会在所有request
都resolve
时才会进then
方法,并且把所
有结果以一个数组返回,只要有一个失败,就会进catch
。而如果在单个请求中定义了catch
方法,那么就
不会进Promise.all
的catch
方法。因此,可以在单个的catch
中对失败的promise
请求做处理,可以使
成功的请求正常返回。