首页
题库
公司真题
专项练习
面试题库
在线编程
面试
面试经验
AI 模拟面试
简历
求职
学习
基础学习课
实战项目课
求职辅导课
专栏&文章
竞赛
搜索
我要招人
发布职位
发布职位、邀约牛人
更多企业解决方案
AI面试、笔试、校招、雇品
HR免费试用AI面试
最新面试提效必备
登录
/
注册
爱写前端的牛牛
门头沟学院 前端工程师
发布于湖北
关注
已关注
取消关注
不错不错
@拉baba小魔仙:
滴滴 前端 秋招面经
主要项目+八股+编程题,全程1h11min好像对于有工作经验的同学来说,会更侧重考察实战场景题、性能优化自我介绍有过实习经验是吧,说说你遇到过最亮点或者最具备技术难点的项目详细介绍一下Vuex,你是怎么理解全局状态管理的?(感觉没说出面试官想要的答案)Vuex是一个全局状态管理工具,全局状态管理的意思就是集中地存储应用的所有组件的状态。如何理解的:假如我们现在有一个应用,这个应用包含驱动应用的数据源、视图和Action对吧。这三个部分构成一个单向数据流,但是当我们的应用遇到多个组件去共享同一个状态的时候,比如说,一个组件的状态改变了,多个依赖于这个组件的页面都要跟着变,相反,来自不同页面的行为需要变更同一个状态,这样都会导致我们的组件状态很混乱,也不好维护,尤其是对于大型项目来说。所以Vuex的作用就体现在这里,他让我们可以把组件的共享状态抽离出来,以一个全局单例模式去管理。Vuex 的核心概念有五个:State: State是用于存储应用中的全局状态(数据)。在 Vuex 中,State 是一个唯一的公共数据源,所有共享的数据都要统一放到 State 中。State 以独立的对象形式存在,并且是响应式的,当 State 发生变化时,与 State 相关的视图会自动更新。Getter: Getter是用于获取 State 中的数据并进行一定程度的计算或处理。它类似于计算属性,可以根据 State 中的数据计算出新的数据,并且会缓存计算结果。当 State 中的数据发生变化时,Getter 会自动重新计算。Mutation: Mutation是用于更改 State 的唯一方法。它是一个同步操作,通过提交类型和处理函数来实现 State 的更改。提交类型表示 State 将发生哪种类型的变化,如增加、删除或更新等;处理函数用于处理具体的状态更新逻辑。在 Vuex 中,每个 Mutation 都有一个类型和处理函数,且必须是同步执行的。Action: Action是用于异步操作的。它可以包含任何异步逻辑,如 API 请求、延时操作等。当异步操作完成后,Action 会提交一个 Mutation 来改变 State。这样可以确保异步操作不会直接改变 State,而是通过 Mutation 以同步的方式更新 State。Module: Module是用于将 Vuex Store 分割成模块化的方式。当应用变得庞大时,可以将不同的功能模块分组存储在不同的 Module 中,以便更好地管理和维护。每个 Module 都有自己的 State、Getter、Mutation 和 ActionVue2和Vue3的差异Vue2生命周期页面上从输入url到渲染页面经历了什么(很久没看这个问题了,下面是我印象里的答案)你详细说一下DOM解析到渲染之间的过程(我提到了重绘重排)那你说一下什么是重绘重排说说浏览器缓存HTTP有哪些状态码?分别说说代表着什么含义2xx:成功常用:200:请求成功201:请求成功,并且服务器已创建新的资源;比如说用户提交表单的场景。204:假设用户访问一个网页,请求服务器获取某个资源的最新版本。服务器检查资源后发现,该资源自上次请求以来没有发生变化。当服务器返回 204 状态码时,浏览器会认为资源可能会发生变化,所以不会使用缓存副本,而是重新下载资源。3xx:重定向常用:302:表示请求成功,但服务器临时性地返回了一个重定向响应;比如说是用户访问网页重定向到登录页的场景。304:表示请求成功,但服务器没有返回任何新内容。和204类似。需要注意的是,204和304的区别在于缓存机制。304 状态码告诉浏览器应该检查本地缓存,看是否可以重用之前的缓存。而 204 状态码则告诉浏览器不要使用缓存,因为资源没有发生变化。4xx:客户端错误5xx:服务端错误有什么性能优化的手段吗(下面是我提到的几个点)路由懒加载:当打包构建应用的时候,JavaScript包会变得很大,如果不做处理,页面加载会变得很慢。用路由懒加载的方案可以让路由被访问的时候才加载对应组件。路由懒加载的表现形式:我一般是在路由表里面的components后面,把路径用import的方式引入。来个场景题 如何监测页面白屏?我理解问题:计算白屏时间面试官:不是,是我们要怎么才能知道页面出现了白屏?(说实话完全没接触过,一点思路都没有)页面白屏通常指的是在加载网页时,用户看到的是一片空白的页面,没有显示任何内容。要监测页面白屏,可以在以下几个环节进行介入:网络请求阶段:可以通过网络请求监测工具,如浏览器开发者工具(Network 面板)、性能分析工具等,查看请求的时间线和请求状态。如果发现页面的请求时间过长或某些请求失败,可能是网络连接或资源加载出现了问题,导致页面无法正常加载。HTML 解析和渲染阶段:在浏览器的开发者工具中,可以查看页面的渲染情况和渲染时间线,以及DOM树和CSSOM树的构建过程。如果在这些过程中出现了错误或者卡顿,可能会导致页面白屏。同时,也可以检查是否存在缺少必要标签、CSS 文件引入错误、JavaScript 错误等问题。JavaScript 执行阶段:JavaScript 的执行会阻塞页面的渲染。如果页面中的 JavaScript 代码存在性能问题、死循环、长时间运行等情况,可能会导致页面无法正常渲染。可以使用浏览器的性能分析工具来检查 JavaScript 执行的情况,查找潜在的性能问题。页面逻辑问题:有时候页面白屏是由页面逻辑问题造成的,比如缺少必要的数据、错误的跳转逻辑等。可以通过日志记录、错误监控工具等手段来捕获和分析错误信息,以便找到并解决页面逻辑问题。在监测页面白屏时,建议使用多种工具和方法综合分析。可以结合网络请求监控、性能分析工具、浏览器开发者工具和错误监控工具等来全面了解页面加载和渲染的各个环节,以便及时发现问题并进行优化。页面白屏的主要原因可以归纳为以下几点:网络问题:网络连接不稳定、服务器响应缓慢或失败等,导致页面无法成功加载所需资源。HTML结构错误:HTML代码中存在语法错误或标签闭合不完整等问题,导致浏览器无法正确解析和构建DOM树。CSS问题:CSS文件加载失败、样式表错误、选择器匹配问题等,导致页面无法正确渲染样式,显示为空白。JavaScript问题:JavaScript代码错误、执行阻塞、性能问题等,导致页面无法正常执行脚本,进而导致页面无法渲染和展示内容。资源加载问题:图片、字体、脚本等外部资源加载失败或超时,导致页面无法显示对应的内容。服务器端问题:服务器端处理逻辑错误、数据库连接问题等,导致无法正确生成页面内容并返回给客户端。第三方插件或库问题:使用的第三方插件或库存在版本兼容性问题、加载失败等,影响了页面的渲染和展示。写两道题吧function fn() { console.log(1);}let timeWorker = {}; // 全局变量// 实现setIntervalfunction mySetInterval(fn, delay) { let key = Symbol(); let execute = function (fn, delay) { timeWorker[key] = setTimeout(function () { fn(); execute(fn, delay) }, delay) } execute(fn, delay); return key;}let timerID = mySetInterval(fn, 1000);// 实现clearIntervalfunction myClearInterval(key) { if (key in timeWorker) { clearTimeout(timeWorker[key]); delete timeWorker[key]; }}setTimeout(()=>{ myClearInterval(timerID);},5000)发现问题不扎实的知识点:VuexVue2和Vue3的差异(起码要说得人家认可你学会了这两个东西)DOM解析到渲染之间的过程性能优化手段HTTP状态码好好总结上述知识点,时常温习。
点赞 6
评论 1
全部评论
推荐
最新
楼层
暂无评论,快来抢首评~
相关推荐
12-24 18:24
新易盛_数据系统部_数据中心系统工程师(准入职员工)
小天才内推,小天才内推码
小天才26秋招分享(三面凉经)tl:9.13投递-10.10自主约面-10.10一面-10.11上传作品集-10.14二面-10.16三面(交叉面) 一面:线上邮件通知选择具体面试时间段(大约20mins)面试官问题1. 请先做一个自我介绍(1分钟左右)。2. 简历项目追问3. 在校期间有获得哪些奖学金吗?4. 有挂过科吗?5. 学得最好的课程是哪些?6. 分享一个人力资源领域中你觉得很重要的知识点。7. 根据以上追问若干问题8. 结合实习经历,招聘的具体成果是你直接负责的社招岗位吗?9. 你的导师对你的工作评价是什么样的?10.追问11.综合实习经历,你目前更适合做人力哪个方向的工作?12....
点赞
评论
收藏
分享
12-23 21:38
腾讯_HR(准入职员工)
腾讯云智研发内推,腾讯云智研发内推码
真实体验是有超好的导师制定成长计划,全程辅导,各种腾讯内部学习网站和资料,上下班班车接送,然后基本一月团建一次。工作压力中等,百分之70情况能6点多下班,其他情况一般在8点左右。早投递,早筛选,早拿offer.!!!敲重点 用我的内推码投递后一定要评论区留言mark一下,以后好找我查进度,我秋招就是随便填别人的内推码,后来查进度都不知道找谁。惨痛的经历。腾讯集团旗下|云智研发公司26届校招内推启动!【公司简介】云智研发公司是腾讯旗下的子公司,公司坚持投资区域书,布局研发人才,聚集云和智慧产业基础产品和行业标准产昂的研发。推进云与产业互联网战略落地,助力产业数字化转型升级,公司规模超过5000人...
腾讯云智研发成长空间 5088人发布
点赞
评论
收藏
分享
11-01 08:02
西南石油大学 后端工程师
团子实习第二周有感
北漂实习的第二周,意识到团子是真的开水。。食堂每顿饭是20以上的(一荤一素),这样一天就会吃掉40,再加上交通住宿等等费用,一天的成本下来高达200+,一个月就是6000+,相当于在团子的赚的米都在团子花。如果是点外卖吃拼好饭,拼好饭都要13、14,还不如去吃食堂(食堂起码会干净非常多)。许愿我的工资能++
StephenZ_:
你这一天住宿一百多?那住的得很好了
点赞
评论
收藏
分享
12-24 16:50
银河通用_数据产品经理(准入职员工)
银河通用内推,银河通用内推码
📍面试公司:银河通用机器人👜面试岗位:机器人开发实习生📖面试问题:介绍下实习的项目,这个项目它本身要完成什么任务,你在里面做了哪些东西?C++ 里边的联合体和结构体有什么区别?内存管理方面的区别?如果联合体类型不一样呢?比如说你这个联合体里边有 int 型,又有 bool 型,又有其他类型,它那占用的空间由谁决定?结构体跟类的区别?类的成员默认如果什么都不加的话,它默认是什么权限呢?C++ 的多线程用过吗?detached 是什么?介绍一下 C++ 的单例模式。Python 的多线程和协程?Python 列表跟元组有什么区别?Python 的这个装饰器你用过吗?ROS1 的常用通信机制。...
点赞
评论
收藏
分享
评论
点赞成功,聊一聊 >
点赞
收藏
分享
评论
提到的真题
返回内容
全站热榜
更多
1
...
工作半年后更确定:我们依然不欠优绩主义什么
6104
2
...
我建了一个分享实习业务的仓库,欢迎大家贡献哦
3792
3
...
牛客2025年终报告重磅上线——揭晓你的年度修炼成就!
3160
4
...
#牛客2025仙途报告#居然是五颗星
2528
5
...
腾讯 微信支付一面面经
2517
6
...
【2025-年终总结】25届毕业生果果牛这一年~
2184
7
...
牛客年终报告,今日道爷我成了
1964
8
...
一个程序员的自救书|从酒吧陪玩DM到上岸大厂
1918
9
...
在当下这个社会,在人生这个无常的时代,我真心希望你和各位牛友开心
1418
10
...
壕壕壕,京东发7个月年终,此生要做东孝子
1316
创作者周榜
更多
正在热议
更多
#
牛客2025仙途报告
#
15939次浏览
270人参与
#
元旦假期你打算怎么过
#
1313次浏览
41人参与
#
找工作,行业重要还是岗位重要?
#
87781次浏览
1758人参与
#
实习没人带,苟住还是跑路?
#
615次浏览
19人参与
#
参加过提前批的机械人,你们还参加秋招么
#
105197次浏览
1647人参与
#
我们是不是被“优绩主义”绑架了?
#
2362次浏览
87人参与
#
今年你最想重开的一场面试是?
#
14125次浏览
150人参与
#
没有家庭托举的我是怎么找工作的
#
32026次浏览
263人参与
#
礼物开箱Plog
#
3456次浏览
105人参与
#
秋招落幕,你是He or Be
#
23518次浏览
398人参与
#
一人说一个提前实习的好处
#
25131次浏览
324人参与
#
你面试体验感最差/最好的公司
#
30434次浏览
503人参与
#
机械人晒出你的简历
#
148614次浏览
886人参与
#
你有哪些缓解焦虑的方法?
#
44676次浏览
868人参与
#
工作中听到最受打击的一句话
#
13695次浏览
185人参与
#
实习要如何选择和准备?
#
130462次浏览
1514人参与
#
设计人的面试记录
#
176946次浏览
1575人参与
#
上班后和你想的一样吗?
#
95259次浏览
701人参与
#
牛油的搬砖plog
#
163969次浏览
1154人参与
#
双非本科的出路是什么?
#
189581次浏览
1500人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务