腾讯音乐前端一面

#腾讯音乐工作体验# 1、项目中登录怎么设计的,有没有考虑哪些安全性问题,token怎么设计,为什么不使用cookie?
3、网络安全XSS、CSRF
2、关于存储除了cookie、localStorage和sessionStorage,其他有了解到吗?
3、长列表怎么优化?
4、图片懒加载怎么实现?
5、pinia实现的数据动态更新,内部原理是什么?
6、vue-router怎么实现的,有了解过浏览器哈希吗?
7、vue3的生命周期的理解(获取dom节点要在哪个钩子里面实现)?
8、浏览器的缓存(强缓存和协商缓存)?
9、css如何实现页面居中布局?
10、动画,做一个跟随手指滑动的组件怎么实现?比如说轮播图
11、promise状态机,怎么捕获错误?promise的理解
12、原型链的理解
13、做过什么组件封装

总是一面挂,二面到底长什么样子?
(菜就多练 to我自己)
全部评论
跪了
点赞 回复 分享
发布于 2024-04-10 23:44 上海
跪了😘
点赞 回复 分享
发布于 2024-04-10 22:17 广东
24校招的吗 校友
点赞 回复 分享
发布于 2024-04-10 18:43 广东

相关推荐

一、面试基本情况本次面试主要围绕 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道真题和解析
点赞 评论 收藏
分享
使用ECharts与后端进行数据交互和异步加载大数据,可以通过以下步骤来实现:https://www.nowcoder.com/issue/tutorial?zhuanlanId=Mg58Em&uuid=bb776ebc550a4fb39023bb015336ee9f后端数据准备:在后端编写相应的接口,以便前端可以通过Ajax或其他HTTP请求方式获取数据。后端可以根据需求从数据库或其他数据源中提取数据,并将其以合适的格式返回给前端。前端页面准备:在前端页面中引入ECharts库,并创建一个容器元素用于显示图表。可以使用CDN引入ECharts,或者下载ECharts库文件到本地并引入。异步加载数据:通过Ajax等方式向后端发送请求,获取数据。可以使用浏览器内置的XMLHttpRequest对象,也可以使用第三方库(如jQuery的$.ajax方法)。在请求中指定后端接口的URL、请求类型、数据格式等。数据处理与图表更新:在成功获取了后端返回的数据后,对数据进行相应的处理,使其符合ECharts的要求。可以根据数据结构和图表类型,使用ECharts提供的API方法进行数据处理、转换和设置。然后调用setOption方法将处理后的数据更新到图表中。图表渲染:通过调用ECharts的init方法初始化图表,并将图表实例与容器元素关联起来,使图表能够在页面上正确显示。然后调用setOption方法,将经过处理的数据传入,图表会根据数据生成相应的图形。通过以上步骤,可以实现前端与后端的数据交互和异步加载大数据。需要注意的是,在处理大数据时,要进行必要的性能优化,如分页加载、数据压缩等,以确保页面的响应速度和用户体验。另外,如果后端返回的数据量较大,建议使用服务器端分页、缓存或其他技术手段进行优化,以避免前端负担过重导致性能问题。
前端学习交流
点赞 评论 收藏
分享
评论
7
32
分享

创作者周榜

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