我是一名前端工程师,艰深地说,就是一只程序猿。
尽管大学业余也确实是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的事件循环机制,不会上来就问概念,而是换个角度,从题目动手,看你是否真正把握。所以对于概念的了解真的很重要。