面试官视角:面试时他们在想什么?
Athena 2019-10-17 来源 : 阅读 34 评论 0

摘要:面试时如果揣摩不清面试官的想法那么将有可能和自己心仪的工作失之交臂,这篇文章将从面试官的角度来写。

很多面试者在面试时的心情都不一样,有的错综复杂,有的信心满满,也有许多人好奇,面试官在面试时究竟在想些什么?他们会从哪几方面来考量求职者,只有足够知道对方的心态才能对面试有更十足的把握,知道这些问题的答案不应该是面试官决定是否录用你的依据。这些知识点都是候选人在日常工作中需要了解,理解和实现的。


面试官视角:面试时他们在想什么?



下面小编就为大家带来面试官第一视角下的面试场景

让我们相互了解对方

在许多情况下,面试将通过 Skype 或其他语音(或语音+视频)通信平台进行。尝试去了解有可能成为员工的人是一个让他们放开自己的好方法。


你能告诉我一些你以前的工作,你是如何适应团队的吗?你的职责是什么?

了解这个人在他以前的公司做了什么(如果他被允许分享的话)是一个很好的开始。这给你一些关于他以前工作经验的基本想法:软技能(我是……的唯一开发人员我和我的同事……”我管理了一个由 6 名开发人员组成的团队……”)和硬技能(“ ……我们创建了一个一百万人使用的应用程序“……我帮助优化了应用程序的渲染时间“……创建了很多自动化测试)。


对你来说 React 的主要卖点是什么。为什么选择使用 React?

我并不期望你提到 JSX,VDOM 等等。—— 我们已经可以通过阅读 React 主页上的“特色”导语得到这些东西。 为什么使用 React

是因为易上手,难掌握API(和其它解决方案相比它的确是非常轻量)?好 —— 这么说的话,意味着你愿意学习新事物,并且随学随用。

是因为更多的就业机会吗?不错 —— 你是一个能够适应市场的人,并且在下一个大框架到来的 5 年内不会有任何问题。我们已经有足够的 jQuery 开发人员了。

想想这有点像电梯游说情景(你和你的老板在电梯里,并且需要说服他在 20 楼走出电梯门之前使用新技术)。我想知道你是否了解 React 能给用户和开发者带来什么好处。


让我们开始聊些更有技术性的问题

正如我在一段开头提到的那样 —— 我不会问你 VDOM 是什么。我们都知道它,但我会问你……


什么是 JSX 和我们怎样在 JavaScript 代码中书写它 —— 浏览器是如何识别它的?

你知道 —— JSX 只是一种 Facebook 普及的标记语法,受益于 Babel/TSC 这些工具 —— 我们能够以一种更令赏心悦目的方式书写 React.createElement 调用。

为什么我会问这个问题?我想知道你是否理解 JSX 的技术原理以及随之而来的限制:为什么甚至在我们的代码并没有使用 React 的情况下,也需要在文件顶部 import React from 'react';为什么组件不能直接返回多个元素。


加分题:为什么 JSX 中的组件名要以大写字母开头?


        能回答出 React 如何知道要渲染的是组件还是 HTML 元素就够了。

额外加分点:此规则有很多例外。例如:把一个组件赋给 this.component 并且写 <this.component /> 也会起作用。


React 中你可以声明的两种主要组件类型是什么以及使用时怎样在两者间选择?

一些人会认为这道题是关于展示组件和容器组件的,但实际上是关于 React.Component 和函数组件。

恰当的回答应该提及生命周期函数和组件状态。

由于我们提到了生命周期 —— 你能跟我讲一遍挂载状态组件的生命周期吗?哪些函数按何种顺序被调用?你会把向 API 的数据请求放在哪里执行?为什么?

好,这个问题有点长。请随意把它分成两个小问题。你现在会想但你说你不会问关于生命周期的内容啊!。我不会问,我不关心生命周期。我关心的其实是最近几个月生命周期发生的变化。

如果回答包含 componentWillMount,你可以假设此人一直在使用旧版本的 React,或者学了一些过时的教程。两种情况都会引起一些担忧。getDerivedStateFromProps 才是你在寻找的答案。

额外加分点:提到在服务端上处理方式不同。

关于数据获取的问题也是如此 —— componentDidMount 是你想要/听到的之一。


加分题:为什么用 componentDidMount 而不是 constructor
     你希望听到的两个原因会是:在渲染发生之前数据不会存在” —— 虽然不是主要原因,但它向您显示该人员了解组件的处理方式; “React Fiber 中使用新的异步渲染……” —— 有人一直在努力学习。


我们刚才提到通过 API 获取数据 —— 你是如何保证在组件重新挂载之后不会重新获取数据?

我们假设不存在缓存失效。这个点和 React 关联性并不大,不过如果回答限制在 React 范围内,也是不错的 一 也许他使用的 GraphQL 的方法对你来说过于繁重?

我问这个问题的目的,是考察候选人是否理解在应用中 UI 需要与其他层解耦的理念。可以提及一个 React 架构外部的 API


你能解释下“状态提升”理念吗?

好,我确实问了一些典型的 React 问题。不过这一个是至关重要的,允许你给候选人一些放松空间。

首选答案是它允许你在兄弟组件间传递数据它允许你拥有更多纯展示组件,更易复用。在这里也许会提到 Redux,不过这可能也是一件坏事,因为它表示候选人只是跟随社区推荐的任何东西,而不理解他为什么需要它。


加分题:如果不能在组件间传递数据,你怎样给多级组件传递数据?

 自从 React 16.3 开始,Context 已经成为主流 —— 它之前就已经存在了,不过文档是缺失的(有意为之)。如果能在解释出 Context 的工作方式(同时能表现出知道 function-as-child 模式)会是加分项。

如果这里能提到 Redux MobX 也很好。


React 生态

开发 React 应用只是流程的一部分 —— 还有更多的要做:调试、测试和文档。


你是怎样调试 React 代码问题的,你用哪些工具?你会怎样调查组件没有重新渲染的问题?

每个人都应该熟悉像 lintereslintjslint)和调试工具(React Developer Tools)这些基本工具。

使用 RDT 来调试问题并通过检查组件 state/props 是否正确是一个不错的答案,如果能提到用 Developer Tools 来打断点也是很好的回答。


你用过哪些测试工具来写 unit/E2E 测试?快照测试是什么及它的好处?

在大多数情况下测试是不可避免的麻烦,但它们又是我们所需要的。有很多优秀的答案:karmamochajasminjestcypresseleniumenzymereact-test-library 等等。最糟糕的事是候选人回答上一家公司我们不做单元测试,只有人工测试

快照测试部分的回答依赖于你的项目里用了什么;如果你觉得它不是很有用就不要问及。但是如果觉得有用 —— 答案就是用于 HTML + CSS 生成的 UI 层的便捷回归测试


技术问题环节完毕

这应该足够你了解候选人的技能了。不过你还要为开放问答留一些时间。


你在过去的项目里遇到的最大问题是什么?你最大的成就?

这就回到第一个问题了 —— 答案可能因开发人员以及职位而异。初级开发人员会说他最大的问题是在一个复杂的过程中报错,但他可以征服它。寻找更高级职位的人将解释他如何优化应用程序性能,而带领团队的人会解释他如何通过结对编程提高速度。


如果你有无限的时间预算并让你解决/提升/改变你最后一个项目里的一项东西,你会选什么,以及为什么选它?

而别的开放问题则要看你要在候选人身上寻找什么。他会尝试用 MobX 替换 Redux 吗?改进测试设置?写出更好的文档?

以上是面试官在面试时的一些心路历程,在考核过程中,面试官不仅是对你的工作能力和基础知识进行考核,还有综合素质等等各方面,希望这篇文章对即将面试的你有所帮助。

         科技引领新发展,学计算机就来职坐标课堂。

本文由 @职坐标 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论
本文作者 联系TA

本人对待工作认真负责,善于沟通、协调有较强的组织能力与团队精神 ; 活泼开朗、乐观上进、有爱心并善于施教并行 ; 上进心强、勤于学习能不断提高 自身的能力与综合素质。在未来的工作中,我将以充沛的精力,

  • 2
    推荐岗位
  • 100
    人气
  • 0%
    受欢迎度

已有0人表明态度,0%喜欢该职业规划老师!

进入TA的空间
名师指导 直通车
  • 索取资料 索取资料 索取资料
  • 答疑解惑 答疑解惑 答疑解惑
  • 技术交流 技术交流 技术交流
  • 职业测评 职业测评 职业测评
  • 面试技巧 面试技巧 面试技巧
  • 高薪秘笈 高薪秘笈 高薪秘笈
TA的其他文章 更多>>
如何解决编程语言之间的差异性?从这几点出发!
就业趋势 0% 的用户喜欢
可以编写代码的代码:代码生成的利与弊
就业趋势 0% 的用户喜欢
哪三大计算机专业人才缺口大,毕业就高薪!
就业趋势 0% 的用户喜欢
何为互联网思维,IT人必须知道的思维方式!
就业趋势 0% 的用户喜欢
云计算规模逐年增长,2023年将超3000亿!
就业趋势 0% 的用户喜欢

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:13167058313
小职老师的微信号:13167058313

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    ICP许可  沪B2-20190160

站长统计