我是一名前端工程师,艰深地说,就是一只程序猿。

尽管大学业余也确实是IT相干业余,但求学期间划水四年,幸运未挂科并顺利毕业,找的第一份工作是软件公司的销售类职位,想着多少也算业余相干欢快入职,却无论如何适应不了酒桌上的觥筹交错,工作得痛苦不堪。某天一激动辞了职,而后因为下一步没有方向开始了漫长的就业生涯。

我曾经记不太分明为什么本人过后要抉择前端开发这一方向了。不过前端入门的确简略,不须要一点编程常识你就能做出一个丑陋的动态页面,甚至还能做出动画成果,总而言之,非常容易让人有成就感。或者这就是起因吧。

学习了差不多半年,次要是看网上的视频课程,买了一些学习前端的最新的书籍,刷了很多公司面试题,我开始找工作,而后发现岗位尽管不少,但邀请面试的少之又少。

转行后的第一份工作

第一个面试机会来自一家初创公司,面试之前我缓和到胃不难受。面试官含糊其辞地问我一天能做几个页面。我愣住了,答复从未测试过,所以不好说,于是他现场让我做了一个简略的页面当作测试,而后对速度示意大略称心,随即示意我通过了面试。

我对这样的草率感到大为吃惊,又理解到公司并没有其余前端人员,思量之下还是回绝了这个机会。

在面试我当初所在的这家公司的时候,总监面试我的时候问:“为什么之前始终自学,当初却决定进去找工作?”

我答复:“因为没钱了要过不下去了。”

起初公司老板面试我的时候,问我:“有没有本人学习能力不错的实际证明?”

我想半天答复刚刚总监说我学得还挺快的。

起初我把面试的过程讲给同学听的时候,他笑得前仰后合。不过好在这场面试的终局是好的——我顺利入职啦。

在这家公司做了大略一年半之久,因为集体职业谋求,这家公司无奈提供本人业余和职业倒退的条件,心愿换一家公司,争取到倒退的条件。

这次和之前刚转行找工作不一样,投的都是一些大厂,心愿本人当前有更好的倒退,当然了啦,大公司工资终点高,福利待遇好,这个是毋庸置疑的。

投了很多公司,字节跳动算是比拟心仪的公司,在面试前筹备了很久,刷了很多面试题,,能够说筹备得非常充沛了。

面经局部

一面-70mins

  • 屏幕正中间有个元素A, 随着屏幕宽度的减少,
    始终须要满足以下条件:

    • A元素垂直居中于屏幕*
    • A元素间隔屏幕左右边距各10px;
    • A元素外面的文字”A”的font-size:20px;程度垂直居中;
    • A元素的高度始终是A元素宽度的50%; (如果搞不定能够实现为A元素的高度固定为200px;)
    • 请用 html及css 实现

函数中的 arguments 是数组吗?若不是,如何将它转化为真正的数组

请说出以下代码打印的后果

 if ([] == false) {console.log(1);}; if ({} == false ) {console.log(2);}; if ([]) {console.log(3);}; if ([1] == [1]) {console.log(4);};

请说出以下代码打印的后果

 async function async1() { console.log('async1 start'); await async2(); console.log('async1 end'); } async function async2() { console.log('async2'); } console.log('script start'); setTimeout(function () { console.log('setTimeout'); }, 0); async1(); new Promise(function (resolve) { console.log('promise1'); resolve(); }).then(function () { console.log('promise2'); }); console.log('script end');

实现ES5中Function原型的bind办法, 使得以下程序最初能输入'success'

 function Animal(name, color) {  this.name = name;  this.color = color; } Animal.prototype.say = function () {  return `I'm a ${this.color} ${this.name}`; }; const Cat = Animal.bind(null, 'cat'); const cat = new Cat('white'); if (cat.say() === 'I\'m a white cat' && cat instanceof Cat && cat instanceof Animal) {  console.log('success'); }

请用算法实现,从给定的无序、不反复的数组data中,取出n个数,使其相加和为sum。并给出算法的工夫/空间复杂度 。(不须要找到所有的解,找到一个解即可)

 function getResult(data, n, sum) { }
  • 反诘环节

一面完结,第二天下午hr打电话约二面。

二面-45mins

代码运行后果

var a = function () { this.b = 3; }var c = new a();a.prototype.b = 9;var b = 7;a();console.log(b);console.log(c.b); 
  • JS继承如何实现
  • repeat 实现,应用JS实现一个repeat办法,调用这个 repeatedFunc("hellworld"),会alert4次 helloworld, 每次距离3秒
function repeat(func, times, wait) {}const repeatFunc = repeat(alert, 4, 3000)
  • 代码题 + 逻辑:给定一个整数数组,每个元素大小都在 1- 100 之间,对这个数组进行排序。范畴扩充到32位整数怎么办?(能够敲代码,也能够讲思路)
  • hash表构造,解决抵触的方法,hash函数有什么类型
  • 凋谢题:学数据结构或者算法过程中,有没有什么中央感觉很奇妙
  • 反诘环节

二面完结,当晚hr打电话约三面,那个冲动啊,终于过了二面了

三面-50mins

  • 模式匹配,
    1234567890 ->1,234,567,890(不是简略的JS函数,是应用正则做的,这边踩坑了)
  • 浏览器的缓存策略
  • 跨域问题
  • 我的项目的技术难点(讲了第一个‘难点’,大佬说,这如同不是难点吧?)
  • JS如何性能监测,如何监测用户页面是否卡顿(不懂,强答,聊了一会大佬说跳过这问题吧)
  • 解决hash抵触的方法
  • 数组和链表的区别
  • 浏览器渲染过程
  • 手头offer状况
  • 为什么抉择前端?
  • 反诘环节

三面有感:前两面都是做题 + 原理的面试状况,三面回归了聊技术的形式。可能因为是大佬面,总感觉压力很大,一股本人凉了的感觉(可能是因为太菜了),每个问题面试都会始终诘问,问到你答不进去为止才换问题。三面总共有两次被面试官说“不聊这个了,咱们换个话题吧”。

三面完结后,真的是慌得一批,复盘完感觉每个问题面试官都不是很称心,感觉凉了,着急得期待后果。恰巧是周五,如果当天等不到后果,那就可能要等到下一周了,果不其然当天没音讯。

周六下午等不住了,发短息问了hr。要特别感谢hr谢谢,非工作工夫帮我查问后果,通知我通过了,第二天会分割我。(心田其实超级冲动)

总结

从转行到当初,差不多两年的工夫,虽不能和大佬相比,但也是学了很多货色。我集体在学习的过程中,习惯简略做做笔记,不便本人温习的时候可能疾速了解,当初将本人的笔记分享进去,和大家独特学习。

集体将这段时间所学的常识,分为三个阶段:

第一阶段:HTML&CSS&JavaScript根底

第二阶段:挪动端开发技术

第三阶段:前端罕用框架

PS

  • 举荐学习形式:针对某个知识点,能够先简略过一下我的笔记,如果了解,那是最好,能够帮忙疾速解决问题;如果因为我的笔记太过简陋不了解,能够关注我当前我还会持续分享。
  • 大厂的面试难在,针对一个根底知识点,比方JS的事件循环机制,不会上来就问概念,而是换个角度,从题目动手,看你是否真正把握。所以对于概念的了解真的很重要。