每日消息!2023前端面试题整理(PDF附答案)
“全方位总结一下所遇到的面试题目,与大家共同学习,也是对自己的一次总结”今天给朋友们分享我花了将近两
“全方位总结一下所遇到的面试题目,与大家共同学习,也是对自己的一次总结”
今天给朋友们分享我花了将近两个月时间,参考了很多网上的优质博文和项目整理的一份比较全面的前端面试题库,还有面试前刷过的题目(其中概括HTML,CSS,JS,React,Vue,NodeJS,互联网基础知识)共有【269页】。很多朋友靠着这些内容进行复习,拿到了BATJ等大厂的offer, 也已经帮助了很多的前端学习者,希望也能帮助到你。
(相关资料图)
【PDF文末获取】前端开发所需掌握知识点概要:HTML&CSS:浏览器内核、渲染原理、依赖管理、兼容性、CSS语法、层次关系,常用属性、布局、选择器、权重、CSS盒模型、Hack、CSS预处理器、CSS3动画 JavaScript: 数据类型、运算、对象、Function、继承、闭包、作用域、事件、Prototype、RegExp、JSON、Ajax、DOM、BOM、内存泄漏、跨域、异步请求、模板引擎、模块化、Flux、同构、算法、ES6、ES7、ES8特性、Nodejs、HTTP 框架和类库: ajax、jQuery、Bootstrap、axios、Vue、Vuex、React、element-ui、layui、webpack
面试题文档十分全面,文末还有答案解析!(文章比较长,耐心看完,让你面试提升一大截!)1、HTML面试题
html 语义化
canvas 相关
svg和canvas的区别?
html5有哪些新特性?
如何处理HTML5新标签的浏览器兼容问题?
说说 title 和 alt 属性
HTML全局属性(global attribute)有哪些
2、CSS面试题
让一个元素水平垂直居中,到底有多少种方案?
浮动布局的优点?有什么缺点?清除浮动有哪些方式?
使用display:inline-block会产生什么问题?解决方法?
布局题:div垂直居中,左右10px,高度始终为宽度一半
盒模型
CSS如何进行品字布局?
CSS如何进行圣杯布局
CSS如何实现双飞翼布局?
什么是BFC?
什么是 Css Hack?ie6,7,8 的 hack 分别是什么?
描述一个”reset”的 CSS 文件并如何使用它。知道 normalize.css 吗?你 了解他们的不同之处?
CSS 中 link 和@import 的区别是?
为什么要初始化样式?
…
3、JavaScript面试题
0.1+0.2为什么不等于0.3?
什么是BigInt?
为什么需要BigInt?
什么是闭包?
闭包产生的原因?
闭包有哪些表现形式?
原型对象和构造函数有何关系?
能不能描述一下原型链?
JS如何实现继承?
null是对象吗?为什么?
call 和 apply 的区别
描述一下 V8 执行一段JS代码的过程?
关于JS中一些重要的api实现
== 和 ===有什么区别?
如何让if(a == 1 && a == 2)条件成立?
…
4、前端框架面试题Vue
Vue 双向绑定原理
描述下 vue 从初始化页面--修改数据--刷新页面 UI 的过程?
你是如何理解 Vue 的响应式系统的?
组件中写 name 选项有什么作用?
vue 中怎么重置 data?
vue 首屏加载优化
vuex是什么?怎么使用?哪种功能场景使用它?
vuex有哪几种属性?
虚拟 DOM 实现原理
Vue 中 key 值的作用?
什么是MVVM?
mvvm和mvc区别?它和其它框架(jquery)的区别是什么?哪些场景适合?
React
React有什么特点?
列出React的一些主要优点。
React有哪些限制?
什么是JSX?
你了解 Virtual DOM 吗?解释一下它的工作原理。
与 ES5 相比,React 的 ES6 语法有何不同?
解释 React 中 render() 的目的。
React中的状态是什么?它是如何使用的?
如何更新组件的状态?
如何模块化 React 中的代码?
React中的事件是什么?
如何在React中创建一个事件?
你对 React 的 refs 有什么了解?
列出一些应该使用 Refs 的情况。
如何在 React 中创建表单
什么是高阶组件(HOC)?
MVC框架的主要问题是什么?
Redux与Flux有何不同?
数据如何通过 Redux 流动?
什么是React 路由?
为什么React Router v4中使用 switch 关键字 ?
…
5、浏览器面试题
能不能说一说浏览器缓存?
能不能说一说浏览器的本地存储?各自优劣如何?
能不能实现事件的防抖和节流?
浏览器缓存
谈谈你对重绘和回流的理解
能不能实现图片懒加载?
说一说从输入URL到页面呈现发生了什么?
能不能说一说XSS攻击?
BOM对象模型
…
6、计算机网络面试题
HTTP 缓存
HTTP 常用的状态码及使用场景?
HTTP 常用的请求方式,区别和用途?
你对计算机网络的认识怎么样
HTTPS 是什么?具体流程
WebSocket与Ajax的区别
TCP 如何保证有效传输及拥塞控制原理。
TCP 协议怎么保证可靠的,UDP 为什么不可靠?
7、一些开放性题目1)说说最近最流行的一些东西吧?常去哪些网站?2)自我介绍:除了基本个人信息以外,面试官更想听的是你与众不同的地方和你的优势。3)项目介绍4)前端开发的职业现状和前景是什么?5)平时是如何学习前端开发的?6)1-3年工作经验,你有信心顺利跳槽到BATJ等一线互联网大公司吗?7)你觉得哪个框架比较好,好在哪里8)你觉得最难得技术难点是什么8、算法题链表面试题:反转单向链表题目需要将一个单向链表反转。思路很简单,使用三个变量分别表示当前节点和当前节点的前后节点,虽然这题很简单,但是却是一道常考题以下是实现该算法的代码var reverseList = function(head) { // 判断下变量边界问题 if (!head || !head.next) return head // 初始设置为空,因为第一个节点反转后就是尾部,尾部节点指向 null let pre = null let current = head let next // 判断当前节点是否为空 // 不为空就先获取当前节点的下一节点 // 然后把当前节点的 next 设为上一个节点 // 然后把 current 设为下一个节点,pre 设为当前节点 while(current) { next = current.next current.next = pre pre = current current = next } return pre };二叉树遍历
原理: 递归
function traversal(node,tempOrderTraversal) { if (node != null) { // tempOrderTraversal.push(node.value) 前序遍历 if (node.left != null) { preOrderTraversal(node.left,tempOrderTraversal) } // tempOrderTraversal.push(node.value) 中序遍历 if (node.right != null) { preOrderTraversal(node.right,tempOrderTraversal) } // tempOrderTraversal.push(node.value) 后序遍历 } }不能使用递归时,则使用栈就是JS的数组push、pop// 非递归遍历 var kthSmallest = function(root, k) { const tempArr = []; let result; tempArr.push(root); while (tempArr.length > 0) { result = tempArr.pop(); if (result.value == k) break; if (result.left != null) tempArr.push(result.left); if (result.right != null) tempArr.push(result.right); } return result; };堆排序堆排序利用了二叉堆的特性来做,二叉堆通常用数组表示,并且二叉堆是一颗完全二叉树(所有叶节点(最底层的节点)都是从左往右顺序排序,并且其他层的节点都是满的)。二叉堆又分为大根堆与小根堆。
大根堆是某个节点的所有子节点的值都比他小
小根堆是某个节点的所有子节点的值都比他大
堆排序的原理就是组成一个大根堆或者小根堆。以小根堆为例,某个节点的左边子节点索引是 i * 2 +1 ,右边是 i * 2 + 2 ,父节点是 (i - 1) /2 。1. 首先遍历数组,判断该节点的父节点是否比他小,如果小就交换位置并继续判断,直到他的父节点比他大2. 重新以上操作 1,直到数组首位是最大值3. 然后将首位和末尾交换位置并将数组长度减一,表示数组末尾已是最大值,不需要再比较大小4. 对比左右节点哪个大,然后记住大的节点的索引并且和父节点对比大小,如果子节点大就交换位置5. 重复以上操作 3 - 4 直到整个数组都是大根堆。
以下是实现该算法的代码function heap(array) { checkArray(array); // 将最大值交换到首位 for (let i = 0; i < array.length; i++) { heapInsert(array, i); } let size = array.length; // 交换首位和末尾 swap(array, 0, --size); while (size > 0) { heapify(array, 0, size); swap(array, 0, --size); } return array; } function heapInsert(array, index) { // 如果当前节点比父节点大,就交换 while (array[index] > array[parseInt((index - 1) / 2)]) { swap(array, index, parseInt((index - 1) / 2)); // 将索引变成父节点 index = parseInt((index - 1) / 2); } } function heapify(array, index, size) { let left = index * 2 + 1; while (left < size) { // 判断左右节点大小 let largest = left + 1 < size && array[left] < array[left + 1] ? left + 1 : left; // 判断子节点和父节点大小 largest = array[index] < array[largest] ? largest : index; if (largest === index) break; swap(array, index, largest); index = largest; left = index * 2 + 1; } }以上代码实现了小根堆,如果需要实现大根堆,只需要把节点对比反一下就好。插入排序将一个新的数,和前面的比较,只要当前数小于前一个则和前一个交换位置,否则终止;时间复杂度:O(N^2);空间复杂度:O(1)以下是实现该算法的代码function insertSort(arr) { if(arr == null || arr.length <= 0){ return []; } var len = arr.length; for(var i = 1; i < len; i++) { for(var j = i - 1; j >= 0 && arr[j] > arr[j + 1]; j--) { swap(arr, j, j + 1); } } return arr; } function swap(arr, i, j){ var temp = arr[i]; arr[i] = arr[j]; arr[j] = temp; }去掉一组整型数组重复的值这道问题出现在诸多的前端面试题中,主要考察个人对Object的使用,利用key来进行筛选。以下是实现该算法的代码let unique = function(arr) { let hashTable = {}; let data = []; for(let i=0,l=arr.length;i快速排序以下是实现该算法的代码def quick_sort(arr): if len(arr) < 2: return arr mid = arr[len(arr)//2] left, right = [], [] arr.remove(mid) for item in arr: if item > mid: right.append(item) else: left.append(item) return quick_sort(left)+[mid]+quick_sort(right) b = [11, 99, 33, 69, 77, 88, 55, 11, 33, 36, 39, 66, 44, 22] print(quick_sort(b))无重复字符的最长子串给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。以下是实现该算法的代码var lengthOfLongestSubstring = function(s) { let window = {}; let left = 0, right = 0; let maxLen = 0, maxStr = ''; while (right < s.length) { let c = s[right]; right++; if (window[c]) window[c]++; else window[c] = 1 while (window[c] > 1) { let d = s[left]; left++; window[d]--; } if (maxLen < right - left) { maxLen = right - left; } } return maxLen; };时间复杂度:O(n2), 其中 arr.indexOf() 时间复杂度为 O(n) ,arr.splice(0, index+1) 的时间复杂度也为 O(n)空间复杂度:O(n)队列队列和栈类似,不同的是队列是先进先出 (FIFO) 原则的有序集合,它的结构类似如下:
常见队列的操作有:enqueue(e) 进队、 dequeue() 出队、 isEmpty() 是否是空队、 front() 获取队头元素、clear() 清空队,以及 size() 获取队列长度。以下是实现该算法的代码function Queue() { let items = [] this.enqueue = function(e) { items.push(e) } this.dequeue = function() { return items.shift() } this.isEmpty = function() { return items.length === 0 } this.front = function() { return items[0] } this.clear = function() { items = [] } this.size = function() { return items.length } }查找:从对头开始查找,从时间复杂度为 O(n)插入或删除:进栈与出栈的时间复杂度为 O(1)
由于篇幅原因,这里只能分享部分面试题的截图,
需要完整面试题PDF的伙伴
点赞评论:面试题
后台打招呼即可!!
关键词:
“全方位总结一下所遇到的面试题目,与大家共同学习,也是对自己的一次总结”今天给朋友们分享我花了将近两
5月11日,据交易商协会官网,基于监管部门反馈线索,依据《银行间债券市场自律处分规则》,交易商协会已对
上海市市北公证处招聘启事招聘岗位与职责招聘岗位:公证员助理岗位职责:协助公证员办理公证事宜。岗位要求
5月11日消息,软银集团5月11日发布截至3月31日的2022财年第四季度及全年财报。全年净营收6 57万亿日元,
B站发布36部纪录片作品推出“探照灯计划”与“恒星计划”
前不久,一场国际性氢能“盛宴”——中欧氢能源产业论坛在包头市召开,来自中国、联合国工业发展组织、丹麦
结合生活经验说说你对一切看上去都是有生命的
近日,郑州多区陆续发布2022年度民办学校(幼儿园)办学情况检查结果。多所学校、幼儿园、培训机构终止办学
中新社海南文昌5月11日电(记者马帅莎)据中国载人航天工程办公室消息,天舟六号货运飞船入轨后顺利完成状态
1、A212、以纯 YISHION3、南极人4、卡洛菲琳5、嫚妃6、逸阳 ESEY7、韩都衣舍 HSTYLE8、娇莉姿9
5月11日,安徽泉盛化工有限公司20万吨双氧水装置正常开机,27 5%双氧水报价1050元 吨,价格持稳。供应趋紧
为进一步保障道路交通安全畅通和施工安全,东莞市公路事务中心拟在2023年5月13日23时~2023年5月14日7时,
欢迎观看本篇文章,小升来为大家解答以上问题。做梦梦见理发是什么意思,做梦梦见理发好不好很多人还不知道
人体春生夏长,秋收冬藏。从立夏开始,接下来的夏三月,是人体“长”的时候。不仅小孩会快速长高,成年人也
5月10日,中国电建集团湖北工程有限公司副总经理、总工程师吴滨在总部会见中国电建集团核电工程有限公司(以
深圳特区报讯(记者吴亚男)第133届中国进出口商品交易会(以下简称“广交会”)日前闭幕,展览面积和参展
健康服务与管理是冷门专业。根据健康服务与管理专业的报考人数分析,该专业是一个冷门专业,但健康服务与管
5月9日,2023年上海市全民数字素养与技能提升月启动仪式在嘉定区举行。此次提升月以“数字赋能全民共享”为
截至2023年5月10日收盘金地集团600383报收于824元下跌214换手率155成交量6992万手成交额578亿元5月10日的资
1、游戏中通过西莉亚的房间传送到【西海岸港口码头】,如图:2、传输完成后,按[n]打开地图,找到NPC[阿贝
为更好满足广大投资人的理财要求,光大保德信基金管理有限公司(以下简称“本公司”)作为光大保德信智能汽
1、因为已经出了很久了(貌似是在我5年级的时候出的吧,偶都是高中生了 )故事写不下去了,没新意了,而且又很
贝多芬的悲伤的原唱是萧风还是郑毅很多人还不知道,现在让我们一起来看看吧!1、郑毅、萧峰是翻唱的、、女
爆吧神器app,爆吧工具这个很多人还不知道,现在让我们一起来看看吧!1、加群。2、共享里有的百度搜索:血色
新湖南客户端5月10日讯(通讯员陈瑾李雪琼)近日衡阳市蒸湘区第二实验小学按照“清廉学校”创建标准和要求
Copyright 2015-2022 人人酒业网 版权所有 备案号:粤ICP备18023326号-36 联系邮箱:8557298@qq.com