高级前端二面常见面试题总结

这篇博客总结了高级前端面试中常见的问题,包括Connection: keep-alive的工作原理和作用,单例模式的实现,Promise.any的用法,以及JavaScript中的类型转换和模板字符串解析等知识点,还探讨了BFC布局、标题标签与样式标签的区别,懒加载的实现原理,正向代理与反向代理的区别,以及浏览器对HTML5离线储存的管理。
摘要由CSDN通过智能技术生成

介绍一下Connection:keep-alive

什么是keep-alive

我们知道HTTP协议采用“请求-应答”模式,当使用普通模式,即非KeepAlive模式时,每个请求/应答客户和服务器都要新建一个连接,完成 之后立即断开连接(HTTP协议为无连接的协议);

当使用Keep-Alive模式(又称持久连接、连接重用)时,Keep-Alive功能使客户端到服 务器端的连接持续有效,当出现对服务器的后继请求时,Keep-Alive功能避免了建立或者重新建立连接。

为什么要使用keep-alive

keep-alive技术的创建目的,能在多次HTTP之前重用同一个TCP连接,从而减少创建/关闭多个 TCP 连接的开销(包括响应时间、CPU 资源、减少拥堵等),参考如下示意图

客户端如何开启

在HTTP/1.0协议中,默认是关闭的,需要在http头加入"Connection: Keep-Alive”,才能启用Keep-Alive;

Connection: keep-alive

http 1.1中默认启用Keep-Alive,如果加入"Connection: close “,才关闭。

Connection: close

目前大部分浏览器都是用http1.1协议,也就是说默认都会发起Keep-Alive的连接请求了,所以是否能完成一个完整的Keep- Alive连接就看服务器设置情况。

单例模式

意图:保证一个类仅有一个实例,并提供一个访问它的全局访问点。

主要解决:一个全局使用的类频繁地创建与销毁。

何时使用:当您想控制实例数目,节省系统资源的时候。

如何解决:判断系统是否已经有这个单例,如果有则返回,如果没有则创建。

实现

var Singleton = (function() {
   
    // 如果在内部声明 SingletonClass 对象,则无法在外部直接调用
    var SingletonClass = function() {
    }; 
    var instance;
    return function() {
   
        // 如果已存在,则返回 instance
        if(instance) return instance;
        // 如果不存在,则new 一个 SingletonClass 对象
        instance = new SingletonClass();
        return instance;
    }
})();

// 测试
var a = new Singleton();
var b = new Singleton();
console.log(a === b);  // true

Promise.any

描述:只要 promises 中有一个fulfilled,就返回第一个fulfilledPromise实例的返回值。

实现

Promise.any = function(promises) {
   
    return new Promise((resolve, reject) => {
   
        if(Array.isArray(promises)) {
   
            if(promises.length === 0) return reject(new AggregateError("All promises were rejected"));
            let count = 0;
            promises.forEach((item, index) => {
   
                Promise.resolve(item).then(
                    value => resolve(value),
                    reason => {
   
                        count++;
                        if(count === promises.length) {
   
                            reject(new AggregateError("All promises were rejected"));
                        };
                    }
                );
            })
        }
        else return reject(new TypeError("Argument is not iterable"));
    });
}

代码输出结果

const first = () => (new Promise((resolve, reject) => {
   
    console.log(3);
    let p = new Promise((resolve, reject) => {
   
        console.log(7);
        setTimeout(() => {
   
            console.log(5);
            resolve(6);
            console.log(p)<
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
回答: 在前端开发中,跨域是指在浏览器发起请求时,请求的目标地址与当前页面的域名不一致,这会导致浏览器的同源策略限制,从而无法正常获取数据。为了解决跨域问题,可以采用以下几种方法:引用\[1\]中提到的方法是通过在服务器端设置响应头信息,允许跨域访问。另外,还可以使用JSONP、CORS、代理服务器等方式来实现跨域请求。引用\[2\]中提到的方法是使用vue-loader来处理vue组件中的代码,使其在解析之前不会出现花屏现象。而引用\[3\]中提到的方法是通过在Vue对象中定义全局指令或在组件内定义指令来实现对DOM元素的操作。这些方法都是解决前端开发中常见问题的有效手段。 #### 引用[.reference_title] - *1* [2023高频前端面试题(含答案)](https://blog.csdn.net/weixin_44672169/article/details/116011608)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [2023高频前端面试题总结(附答案)](https://blog.csdn.net/weixin_45102366/article/details/125525247)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值