三个QA,回答你腾讯+大前端蕴含的可能性

Q:为什么推荐做大前端开发呢?

A:1)客户端更贴近用户,更直接感知用户体验

从客户端技术入手,离产品更近,能清晰感受到产品为用户带来的价值。在整个研发沟通链路上,向前能触达产品和设计的想法、向后能触达后台的技术实现。而且客户端开发在开源社区中的活力很高,能够接触到的技术视野更多,有求知欲的同学能收获不少成就感。

A: 2)技术全面 “什么都沾”,易积累技术经验

在技术上,各个开发类型并没有很清晰的分界线很多技术在各个岗位上是互通的。因为客户端这种“什么都沾点”的特性,即使不再从事客户端开发,在从事其它的开发工作时也会更容易上手。

A:3)还有很大发展空间

99.8%--这个数字是截止2022年底我国网民使用手机上网的比例,而客户端作为移动互联网的一个主要入口,即使现在看来它的体量已经足够大,但因为端的多样性发展,比如:智能汽车、智能眼镜、智能手表等等,仍有相当大的发展空间。

Q:为什么选择来腾讯做大前端开发呢?

A:1)腾讯业务体量够大,能接触更多“疑难杂症“,腾讯有多款亿万量级的C端产品,在客户 端开发过程中,经常会遇到在其他项目中不一定有的“疑难杂症”,当你运用自己的所思所学攻破这些困难,你会觉得自己离成为这个行业和领域的专家更进步,会特别有成就感。

A:2)技术氛围浓厚,导师制培养,不论是实习还是正式入职,作为新人也有同事带,一般日常工作问题都能询问导师和上级;内部还有许多技术讨论会,可以学习团队或者其他同学的技术分享。我们内部还有文档和知识库,相关的业务、技术分享等可以随时查阅学习。部门leader会沟通目标和安排,不会让没有接触过客户端开发的同学直接“做工”;有的团队可能会让同学在实习期先做 demo 练手、再上手小模块开发、最后结合业务需求加入版本开发。

Q:那如何才能加入腾讯呢,求职大前端需要做哪些准备呢?

A:1)重要的事情说3遍:基础、基础、基础,基础知识最重要的,计算机领域相关基础知识是你准备从事软件开发行业的基石,但学知识不等于死记硬背,也不要拘泥于课业中学到的内容,而是需要保持好奇心,每天问自己:这个知识的背景是什么?为什么是这样?前人们这样设计的优点是什么?是什么原因导致不得不这样设计?现在行业里这一方面的知识有更新吗?

A:2)进阶再提升:了解对应开发知识在计算机基础知识之上,去了解对应客户端、前端相关的开发知识,比如客户端 iOS 或 Android 的应用开发、前端Vue/React框架。当然有同学会比较焦虑自己以前没接触过客户端开发是不是很吃亏,其实没必要,分清主次,还是建议优先将重点放在基础知识学习上。

A:3)化知识为实战:参与项目获得工程经验实践永远是最好的尝试。同学们要尝试参与到实际项目中,比如在 GitHub 上多看看和参与一些质量比较高的项目,除此之外,通过实习、加入学校的一些工作室、在市场上寻找一些小项目机会也是不错的选择,这样可以积累一些在课业内难以获取到的工程经验。这个过程中也能将所学知识转化为实战能力。

#腾讯求职进展汇总##腾讯##腾讯2025实习生招聘#
全部评论

相关推荐

一、面试基本情况本次面试主要围绕 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道真题和解析
点赞 评论 收藏
分享
评论
2
2
分享

创作者周榜

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