前端面试题 — 综合(一)

36次阅读

共计 2984 个字符,预计需要花费 8 分钟才能阅读完成。

前言
这篇文章总结一些前端面试过程当中经常遇到的 HTTP、浏览器、SEO 等方面的问题,如果有需要了解其他面试问题的小伙伴,请点击 这里,查看 HTML+CSS+JavaScript 等方面的问题。总结问题,分享给有需要的人(未完待续)
如果文章中有出现纰漏、错误之处,还请看到的小伙伴留言指正,先行谢过
以下 ↓
HTTP 相关
1. HTTP 有什么特点

简单快速:客户向服务器请求服务时,只需传送请求方法和路径
灵活:HTTP 允许传输任意类型的数据对象。正在传输的类型由 Content-Type 加以标记
无连接:无连接的含义是限制每次连接只处理一个请求。服务器处理完客户的请求,并收到客户的应答后,即断开连接 (深入 - 持久连接、管线化)
无状态:HTTP 协议是无状态协议 (Cookie 的出现)

2. http 和 https 协议有什么区别
http: 是互联网上应用最为广泛的一种网络协议,是一个客户端和服务器端请求和应答的标准(TCP),用于从 WWW 服务器传输超文本到本地浏览器的传输协议,它可以使浏览器更加高效,使网络传输减少 https: 是以安全为目标的 HTTP 通道,简单讲是 HTTP 的安全版,即 HTTP 下加入 SSL 层,HTTPS 的安全基础是 SSL,因此加密的详细内容就需要 SSL

http 是超文本传输协议,信息是明文传输,https 则是具有安全性的 ssl 加密传输协议

http 和 https 使用的是完全不同的连接方式,用的端口也不一样,前者是 80,后者是 443

http 的连接很简单,是无状态的;HTTPS 协议是由 SSL+HTTP 协议构建的可进行加密传输、身份认证的网络协议,比 http 协议安全

参考 http 与 https 的区别
3. http 状态码有那些?分别代表是什么意思
常用 http 状态码:

200 OK 服务器成功处理了请求

301/302 Moved Permanently(重定向)请求的 URL 已移走

404 Not Found (页面丢失) 未找到资源

403 服务器拒绝请求

408(请求超时)服务器等候请求时发生超时

501 Internal Server Error 服务器遇到一个错误,使其无法对请求提供服务

502(错误网关)服务器作为网关或代理,从上游服务器收到无效响应

504(网关超时)服务器作为网关或代理,但是没有及时从上游服务器收到请求

更多 参考 这里
4. 什么是 HTTP 持久化和管线化
出现背景:HTTP 最初的版本中,每进行一次 HTTP 通信,就要断开一次 TCP 连接(无连接)
为解决上述问题,HTTP/1.1 增加了持久连接(HTTP Persistent Connections)的方法,其特点是,只要一方未明确提出断开连接,则另一方保持 TCP 连接状态
管线化是指将多个 HTTP 请求整批发送,在发送过程中不用等待对方响应
管线化是在持久连接的基础上实现的,管线化的实现,能够同时并行发送多个请求,而不需要一个接一个的等待响应
5. Http 报文

HTTP 报文是面向文本的,报文中的每一个字段都是一些 ASCII 码串,各个字段的长度是不确定的。HTTP 有两类报文:请求报文和响应报文 HTTP 的这两种报文都由三部分组成:开始行、首部行、实体主体

参考 这里
6. 从输入 URL 到页面加载全过程
参考 这里
7. 为什么利用多个域名来存储网站资源会更有效

CDN 缓存更方便
突破浏览器并发限制
节约 cookie 带宽
节约主域名的连接数,优化页面响应速度
防止不必要的安全问题

浏览器相关
1. 浏览器是由什么组成的
从原理构成上分为七个模块,分别是 User Interface(用户界面)、Browser engine(浏览器引擎)、Rendering engine(渲染引擎)、Networking(网络)、JavaScript Interpreter(js 解释器)、UI Backend(UI 后端)、Date Persistence(数据持久化存储)

其中,最重要的是渲染引擎(内核)和 JavaScript 解释器(JavaScript 引擎)浏览器内核主要负责 HTML、CSS 的解析,页面布局、渲染与复合层合成; JavaScript 引擎负责 JavaScript 代码的解释与执行

2. 浏览器缓存机制
浏览器的缓存机制也就是我们说的 HTTP 缓存机制,其机制是根据 HTTP 报文的缓存标识进行的
参考 这里
3. 浏览器渲染机制
参考 这里
4. 几个很实用的 BOM 属性对象方法
location 对象:主要存储 url 相关信息

history 对象:浏览历史信息相关
history.go() // 前进或后退指定的页面数 history.go(num);
history.back() // 后退一页
history.forward() // 前进一页
navigator 对象:浏览器信息相关
navigator.userAgent // 返回用户代理头的字符串表示 (就是包括浏览器版本信息等的字符串)
navigator.cookieEnabled // 返回浏览器是否支持 (启用)cookie
其他
1. 谈谈你对 SEO 的理解
SEO:搜索引擎优化,其目的是为了使网站能够更好的被搜索引擎抓取,提高在搜索引擎内的自然排名,从而带来更多的免费流量,获取收益 SEO 主要有两种方法,站内优化和站外优化

前端 SEO 优化
2. 前端怎么控制管理路由
路由就是浏览器地址栏中的 url 与所见网页的对应关系
前端路由的实现方式:
基于 hash(ocation.hash+hashchange 事件)
展示层面也就是切换 # 后面的内容,呈现给用户不同的页面。现在越来越多的单页面应用,基本都是基于 hash 实现
特性:

url 中 hash 值的变化并不会重新加载页面

hash 值的改变,都会在浏览器的访问历史中增加一个记录,也就是能通过浏览器的回退、前进按钮控制 hash 的切换
我们可以通过 hashchange 事件,监听到 hash 值的变化,从而响应不同路径的逻辑处理

基于 istory 新 API(history.pushState()+popState 事件)

window.history.pushState(null, null, “http://www.google.com”);

这两个 API 的相同之处是都会操作浏览器的历史记录,而不会引起页面的刷新。不同之处在于,pushState 会增加一条新的历史记录,而 replaceState 则会替换当前的历史记录
详见 History API -MDN
3. 防抖和节流的区别
防抖:任务频繁触发的情况下,只有任务触发的间隔超过指定间隔的时候,任务才会执行节流:指定时间间隔内只会执行一次任务

推荐 这里
4. 页面重构怎么操作
页面重构就是根据原有页面内容和结构的基础上,通过 div+css 写出符合 web 标准的页面结构。
具体实现要达到以下三点:

功能不全页面的重构:页面功能符合用户体验、用户交互结构完整,可通过标准验证,
代码重构:代码质量、SEO 优化、页面性能、更好的语义化、浏览器兼容、CSS 优化
充分考虑到页面在站点中的“作用和重要性”,并对其进行有针对性的优化

后记
这篇文章收集的问题虽然不多,但是每一部分单独拎出来都可以写一篇深入理解,所以还是很需要耐心才可以看完的
这段时间收集了很多前端面试的相关问题,发现有些东西还是很需要深入理解的,有时候仅仅停留在‘会用’的阶段还是远远不够的。所以,后面有时间也会聊一聊自己尝试的东西,发现的问题,有兴趣一起探索的小伙伴可以关注哦
期待同行 GitHub 完整版面试题
以上

正文完
 0