2019搜狐春招前端实习现场面经

今天下午去了搜狐现场面,第一感觉面试官很居高临下,首先是笔试,四个题,不难,第一题是一个半径为4cm的大圆需要几个半径为2cm的小圆才能覆盖?我答错了,面试官拿着我的卷子直接说从来没见过这个答案,我感觉自尊心受损了哈哈哈哈哈哈,然后连自我介绍都不问,直接会用jsonp吗?我说会,然后他说你写一下,我不会,然后就又出了几个题,反正都答得不好,然后就说我想做前端首先得成为一个程序员巴拉巴拉的,哎,感觉有点难受,慢慢来吧,加油


#前端工程师##面经##春招##搜狐#
全部评论
加油!
点赞 回复 分享
发布于 2019-03-15 21:01
加油
点赞 回复 分享
发布于 2019-03-15 20:52
在哪个学校的宣讲啊
点赞 回复 分享
发布于 2019-03-18 18:56
这谁顶得住啊
点赞 回复 分享
发布于 2019-03-15 21:16

相关推荐

一、面试基本情况本次面试主要围绕 React 相关技术、流式传输以及算法与 React Hook 实现展开,包含技术原理问答和两道代码实现题。二、技术问题回顾与解答1. React Router 的实现机制React Router 基于 HTML5 的 history API 实现单页面应用的路由功能。它通过监听浏览器的 popstate 事件(当用户点击浏览器的前进、后退按钮时触发)以及手动调用 history.pushState()、history.replaceState() 方法来更新 URL 地址,同时不触发页面刷新。在 React 组件中,通过 BrowserRouter(基于 history API)、HashRouter(基于 URL 的 hash 部分,兼容性更好)等组件包裹应用,结合 Route 组件定义不同路径对应的渲染组件。当 URL 变化时,React Router 会根据当前路径匹配相应的 Route 并重新渲染对应的组件,从而实现页面内容的更新 。不过在本次面试中,我对这块知识掌握不够扎实,未能完整清晰作答。2. React memo 是做了什么React.memo 是一个高阶组件,用于对函数式组件进行性能优化。它会对组件的 props 进行浅比较,如果前后两次传入的 props 浅比较结果相同,就直接复用之前渲染的结果,不再重新执行组件函数,从而避免不必要的重复渲染。但需要注意,它仅对 props 变化进行比较,当组件内部状态(如通过 useState 创建的状态)变化时,即使 props 未变,组件仍会重新渲染。3. React Suspense 怎么实现的React Suspense 用于处理组件的异步加载情况,让开发者可以指定在异步操作(如数据获取、动态导入组件)进行时显示的加载状态。它通过在组件树中标记一个“等待”区域,当子组件中有异步操作未完成时,会先渲染 Suspense 组件指定的 fallback 内容(如加载动画),直到异步操作完成,再渲染实际的子组件内容。内部实现依赖于 React 的 Fiber 架构,利用 Fiber 的可中断、可恢复特性,在等待异步操作完成期间释放 CPU 资源,不阻塞主线程,提高应用的响应性能 。4. 流式传输相关讨论在讨论流式传输时,我提出可以在前端利用 Server-Sent Events(SSE)实现。SSE 是一种单向的、由服务器向客户端推送数据的技术,适合用于实时数据传输场景。同时,对于 JSON 数据的处理,采用流式解析会更加高效,比如在处理阶乘等数据量较大且逐步生成的场景下,流式解析无需一次性将所有数据加载到内存中,而是边接收数据边解析处理,减少内存占用,提升数据处理效率。三、代码题实现1. 大数相减(考虑负数结果)function subtractLargeNumbers(num1, num2) {function compare(num1, num2) {if (num1.length > num2.length) return 1;if (num1.length < num2.length) return -1;for (let i = 0; i < num1.length; i++) {if (num1[i] > num2[i]) return 1;if (num1[i] < num2[i]) return -1;}return 0;}const sign = compare(num1.split(''), num2.split(''));let larger = sign >= 0? num1 : num2;let smaller = sign >= 0? num2 : num1;let result = '';let carry = 0;for (let i = 0; i < larger.length; i++) {let diff = parseInt(larger[larger.length - 1 - i]) - (parseInt(smaller[smaller.length - 1 - i]) || 0) - carry;if (diff < 0) {diff += 10;carry = 1;} else {carry = 0;}result = diff + result;}while (result[0] === '0' && result.length > 1) {result = result.slice(1);}return sign < 0? '-' + result : result;}2. 实现一个可暂停、继续的倒计时 React Hookimport { useState, useEffect } from'react';function useCountdown(initialTime) {const [time, setTime] = useState(initialTime);const [isRunning, setIsRunning] = useState(true);let intervalId;useEffect(() => {if (isRunning && time > 0) {intervalId = setInterval(() => {setTime(prevTime => prevTime - 1);}, 1000);} else {clearInterval(intervalId);}return () => clearInterval(intervalId);}, [isRunning, time]);const start = () => {setIsRunning(true);};const pause = () => {setIsRunning(false);};return {time,start,pause};
查看6道真题和解析
点赞 评论 收藏
分享
📍面试公司:深圳即构科技💻面试岗位:前端实习❓面试问题:1.拷打LLM大模型项目:(1)实现的过程中遇到的跳转,以及怎么解决答:简单讲了markdown渲染和流式输出的实现(说的很简单)遇到的问题:多端适配(只讲了媒体查询实现)2.拷打智能家居项目:(1)技术选型,架构设计答:简单讲了uniapp的优点,websocket的优点3.八股(1)比较vue2和vue3,vue3好在哪里答:响应式原理vue3可读性更好,API(这块答的不好)(2)vue双向绑定原理答:只用过,原理大概prop监听?(答的稀烂)(3)css盒模型正常回答,(他说我笔试做错了这道题,我忘了怎么这个题都能错)(4)事件循环机制答:先同步,再微任务,再宏任务(让我说了哪些微任务,哪些宏任务)(5)typescript里interface和type都可以用来定义对象吗答:不太懂typescript(6)CI CD流水线的实现答:简单说了用gitlab实现(7)虚拟滚动的原理(8)前端的其他性能优化答:防抖、节流、图片懒加载4.开放问题(1)前端的未来发展,AI的影响答:前端与人交互性强,AI代替不了,但可以用AI帮助开发(大概这种)(2)在项目开发里充当leader,临近deadline,发现了依赖第三方库的bug,怎么解决答:随便乱说的5.反问(1)实习生具体做什么(2)我哪些方面需要加强  表达能力可以,但是让我主动说自己的亮点,讲讲问题怎么解决的(3)面试结果什么时候出🙌面试感想:感觉答的还凑合,但让我说亮点 ,事实上没什么亮点hhhh
查看18道真题和解析
点赞 评论 收藏
分享
06-06 16:08
已编辑
百度_PGC_前端(实习员工)
极致的基础,极致的三件套,没问小垃圾项目,除了作用域提升的题模模糊糊其他都挺顺的(感觉良好)let const var区别,出了一个简单的作用域相关的题箭头函数和普通函数区别,提到了this指针this指针会指向哪,出了一道简单的this指针相关的题说一下知道的块级元素和行内元素标签dom树长啥样,说一下head和body里面一般有啥标签,说一下语义化标签然后跟着我的回答问了一下:script标签可以放在head里面,defer属性和async属性分别异步到什么时候执行js;提到了语义化可以帮助搜索引擎搜到页面,这个是seo;提到了seo,问知道的seo相关的内容,说了四五种,提到了ssr,说一下ssr和ssg和csr的区别;提到了语义化标签,列举一下知道的语义化标签(面试官帮我补充了meta标签,脑子昏了记成了main标签)说一下闭包,举个例子说一下css方面,display属性有哪些上一问说了none,顺便说了一下visibility:hidden也可以隐藏元素但占据位置,不可交互,问为什么不可交互水平垂直居中怎么实现,说了两种就说可以了position属性属性值说一下说一下知道的原生dom操作,怎么往body下面加一个标签spanbfc知道吗,说了怎么触发,有什么用,解决什么问题react更新状态到渲染的底层机制写题,第一道倒计时组件,自动补全关不掉搞得焦头烂额,换了记事本写isequal,还剩三四行快写完了时间要到了,面试官说他知道我思路了,反问问了一下我面的这个业务方面主要做啥的二编:次日通知过了,约二面
查看34道真题和解析
点赞 评论 收藏
分享
评论
点赞
18
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务