第二年,我意外发现了掘金这个网站,我的前端视野一下子广阔了许多,发现很多前所未闻的名词:闭包,ES6,原型,继承, 作用域……
慢慢地,我自学了 React、Vue、原生 JavaScript、NodeJS。
为了学习 Git,我建了 GitHub 账号。
为了搭建 个人博客,购买了 aliyun 的学生服务器和个人域名。一个星期的时间里,我又是配环境,又是学 Linux 命令,第一次用 vim 简直不要太爽,当我的博客在公网成功打开的那一刻,我感觉人生达到了巅峰!
期间,我报名参加了阿里的 D2 会议(虽然当时根本听不懂,凑个热闹),那天特别激动来到西溪园区,看到了好多大牛
大三
一月初,我报名参加了蚂蚁金服体检科技大会,会议更多的是从设计和用户体验角度出发,如何改善产品
见到了 AntD 的创造者:玉伯,云谦等前端大佬
玉伯在开场就发表致歉,因为当年的圣诞节彩蛋事件,轰动不小!
时间来到大三下学期,我想在当地找个实习,于是投递了人生第一份前端实习简历。面试当天,因为紧张,面试官给我递来的纸水杯,在桌子上被我打翻了🤣……幸好,当天晚上就接到了HR的电话,通过了。
在这几个月的实习期内(期间逃了不少课),公司给予了我足够的发展空间,给我配了 MacBook 和 24 寸的显示器。我尝试 搭建脚手架,构建 React 企业应用, 写 H5 页面,从零开发微信小程序 等等。学习如何做到版本控制,规范 Git 提交,一步步实现项目落地,和 UI、产品、测试、后端一同协作开发。在协助我的 mentor 进行面试的时候,偶然看到了我当初的面试评级是 A,高兴了好一阵子。
不过,天下无不散之宴席,意识到要秋招的我,辞去了实习岗位,投入到复习阶段。然后我就被校招好好上了一课,由于我是非科班,根本不懂什么算法,只会简单的数据结构,于是乎在各公司的秋招笔试、面试中,吃尽了苦头。
ps:这里推荐几本书籍和我常用的学习网站(需要翻墙):
- 《图解 HTTP》
- 《JavaScript ES6函数式编程入门经典》
- 《学习JavaScript数据结构与算法》
- 《你不知道的JavaScript》系列
- MDN,淘系前端团队,凹凸实验室
- medium.com/
- codepen.io/
- dev.to/
- developers.google.cn/web/
面经分享
第一部分是我前端面试的经验总结,第二部分是我认为比较有思考空间的题目
经验总结
- 一份漂亮的简历,需要包括以下部分(排版由上而下)
- 个人亮点(专精领域,个人博客,开源项目)
- 教育经历(毕业院校,在校经历、荣誉)
- 工作经历(实习)
- 项目经历
- 专业技能
- 扎实的前端基础,比如你知道
<meta http-equiv='X-UA-Compatible' content='IE=edge,chrome=1'/>
作用是什么?flex:1
的 1 代表什么?Generator
如何抛出错误?- 熟悉一门前端框架(React 优先)
- 勤刷 LeetCode 的算法题,熟悉掌握相应的数据结构如常见的链表、栈、队列、哈希表、树
- 熟悉网络基础、Git 命令、Linux 命令
- 多去了解前端的新趋势(Flutter,PWA,Serveless,GraphQL,CSS Houdini)
- 要有自信,让面试官感受到你对前端的热爱
面试题
由于面试的公司和次数略多,老生常谈的面试题就不放出来了,也不按公司划分面试题了
算法题
大多出自 LeetCode ,LeetCode HOT 100,最好自己过一遍,理解最优解
编程题
-
用 Class 实现 EventEmitter,要求拥有 on,once,emit,off 方法
-
实现 deepClone,要求能成功克隆带有循环引用的对象
-
CSS 实现一个宽度为浏览器1/2,宽高比为 2:1 的盒子
-
实现 sum 函数
sum(1)(2)(3) == 6; // true
sum(1, 2, 3) == 6; // true
复制代码
- 实现 sum2 函数
console.log(sum2(1)(2)(3)()) // 6
console.log(sum2(1, 2, 3)()); // 6
复制代码
-
用尾递归实现 fibonacci 数列
-
实现 co 函数
-
实现以下功能,当对一个 arr 做 push 操作时,会自动打印一行提示消息
const arr = [1,2,3];
arr.push(4);
// arr pushed a new element: 4
复制代码
-
代码实现中断 Promise 的运行
-
有一组图片,实现后一张图片必须等到上一张图片加载完毕,才能开始加载
-
为 Test 类添加方法,打印指定内容
class Test {
constructor() {
this.person = { name: “jack”, age: 38, position: “CTO” };
}
// …
}
const test = new Test();
for (const ele of test) {
console.log(ele);
}
// [ ‘name’, ‘jack’ ]
// [ ‘age’, 38 ]
// [ ‘position’, ‘CTO’ ]
复制代码
- 实现 handler 函数,遇到 b 和 ac 都要去除
console.log(handler(“aabaa”)); // ‘aaaa’
console.log(handler(“abaccbc”)); // ‘c’
console.log(handler(“aaccc”)); // ‘c’
console.log(handler(“aaabccc”)); // ‘’
复制代码
- 实现 decode 函数
decode(‘HG[3|B[2|CA]]F’) === ‘HGBCACABCACABCACAF’ // true
复制代码
- 实现 _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”);
}
复制代码
-
CSS 实现圆环进度条效果
-
说出以下打印内容
console.log(-1 >>> 32);
console.log(-1 << 32);
console.log(1 >> 32);
console.log(5 >>> 2);
var a = { n: 1 };
var b = a;
a.x = a = { n: 2 };
console.log(a.x);
console.log(b.x);
复制代码
简答题
- 实现 F12 开发者工具的检查(inspect)功能
- 实现 把一个盒子从一个区域拖放到另一个指定区域中
- 盒子一部分在区域内,一部分在区域外,该如何处理
- 简述几个封装好的关键方法
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)
核心竞争力,怎么才能提高呢?
成年人想要改变生活,逆转状态?那就开始学习吧~
万事开头难,但是程序员这一条路坚持几年后发展空间还是非常大的,一切重在坚持。
为了帮助大家更好更高效的准备面试,特别整理了《前端工程师面试手册》电子稿文件。
前端面试题汇总
JavaScript
性能
linux
前端资料汇总
完整版PDF资料免费分享,只需你点赞支持,动动手指点击此处就可免费领取了。
前端工程师岗位缺口一直很大,符合岗位要求的人越来越少,所以学习前端的小伙伴要注意了,一定要把技能学到扎实,做有含金量的项目,这样在找工作的时候无论遇到什么情况,问题都不会大。
.png)
前端资料汇总
完整版PDF资料免费分享,只需你点赞支持,动动手指点击此处就可免费领取了。
前端工程师岗位缺口一直很大,符合岗位要求的人越来越少,所以学习前端的小伙伴要注意了,一定要把技能学到扎实,做有含金量的项目,这样在找工作的时候无论遇到什么情况,问题都不会大。