从10个角度来检测自己是不是一个合格的前端工程师

  • 3.有哪些协议是可靠,TCP有哪些手段保证可靠交付

  • 4.DNS的作用、DNS解析的详细过程,DNS优化原理

  • 5.CDN的作用和原理

  • 6.HTTP请求报文和响应报文的具体组成,能理解常见请求头的含义,有几种请求方式,区别是什么

  • 7.HTTP所有状态码的具体含义,看到异常状态码能快速定位问题

  • 8.HTTP1.1HTTP2.0带来的改变

  • 9.HTTPS的加密原理,如何开启HTTPS,如何劫持HTTPS请求

  • 10.理解WebSocket协议的底层原理、与HTTP的区别

设计模式

  • 1.熟练使用前端常用的设计模式编写代码,如单例模式、装饰器模式、代理模式等

  • 2.发布订阅模式和观察者模式的异同以及实际应用

  • 3.可以说出几种设计模式在开发中的实际应用,理解框架源码中对设计模式的应用

四、数据结构和算法


据我了解的大部分前端对这部分知识有些欠缺,甚至抵触,但是,如果突破更高的天花板,这部分知识是必不可少的,而且我亲身经历——非常有用!

JavaScript编码能力

  • 1.多种方式实现数组去重、扁平化、对比优缺点

  • 2.多种方式实现深拷贝、对比优缺点

  • 3.手写函数柯里化工具函数、并理解其应用场景和优势

  • 4.手写防抖和节流工具函数、并理解其内部原理和应用场景

  • 5.实现一个sleep函数

手动实现前端轮子

  • 1.手动实现call、apply、bind

  • 2.手动实现符合Promise/A+规范的Promise、手动实现async await

  • 3.手写一个EventEmitter实现事件发布、订阅

  • 4.可以说出两种实现双向绑定的方案、可以手动实现

  • 5.手写JSON.stringifyJSON.parse

  • 6.手写一个模版引擎,并能解释其中原理

  • 7.手写懒加载下拉刷新上拉加载预加载等效果

数据结构

  • 1.理解常见数据结构的特点,以及他们在不同场景下使用的优缺点

  • 2.理解数组字符串的存储原理,并熟练应用他们解决问题

  • 3.理解二叉树队列哈希表的基本结构和特点,并可以应用它解决问题

  • 4.了解的基本结构和使用场景

算法

  • 1.可计算一个算法的时间复杂度和空间复杂度,可估计业务逻辑代码的耗时和内存消耗

  • 2.至少理解五种排序算法的实现原理、应用场景、优缺点,可快速说出时间、空间复杂度

  • 3.了解递归和循环的优缺点、应用场景、并可在开发中熟练应用

  • 4.可应用回溯算法贪心算法分治算法动态规划等解决复杂问题

  • 5.前端处理海量数据的算法方案

五、运行环境


我们需要理清语言和环境的关系:

ECMAScript描述了 JavaScript语言的语法和基本对象规范

浏览器作为 JavaScript的一种运行环境,为它提供了:文档对象模型( DOM),描述处理网页内容的方法和接口、浏览器对象模型( BOM),描述与浏览器进行交互的方法和接口

Node也是 JavaScript的一种运行环境,为它提供了操作 I/O、网络等 API

浏览器API

  • 1.浏览器提供的符合W3C标准的DOM操作API、浏览器差异、兼容性

  • 2.浏览器提供的浏览器对象模型 (BOM)提供的所有全局API、浏览器差异、兼容性

  • 3.大量DOM操作、海量数据的性能优化(合并操作、DiffrequestAnimationFrame等)

  • 4.浏览器海量数据存储、操作性能优化

  • 5.DOM事件流的具体实现机制、不同浏览器的差异、事件代理

  • 6.前端发起网络请求的几种方式及其底层实现、可以手写原生ajaxfetch、可以熟练使用第三方库

  • 7.浏览器的同源策略,如何避免同源策略,几种方式的异同点以及如何选型

  • 8.浏览器提供的几种存储机制、优缺点、开发中正确的选择

  • 9.浏览器跨标签通信

浏览器原理

  • 1.各浏览器使用的JavaScript引擎以及它们的异同点、如何在代码中进行区分

  • 2.请求数据到请求结束与服务器进行了几次交互

  • 3.可详细描述浏览器从输入URL到页面展现的详细过程

  • 4.浏览器解析HTML代码的原理,以及构建DOM树的流程

  • 5.浏览器如何解析CSS规则,并将其应用到DOM树上

  • 6.浏览器如何将解析好的带有样式的DOM树进行绘制

  • 7.浏览器的运行机制,如何配置资源异步同步加载

  • 8.浏览器回流与重绘的底层原理,引发原因,如何有效避免

  • 9.浏览器的垃圾回收机制,如何避免内存泄漏

  • 10.浏览器采用的缓存方案,如何选择和控制合适的缓存方案

Node

  • 1.理解Node在应用程序中的作用,可以使用Node搭建前端运行环境、使用Node操作文件、操作数据库等等

  • 2.掌握一种Node开发框架,如ExpressExpressKoa的区别

  • 3.熟练使用Node提供的APIPathHttpChild Process等并理解其实现原理

  • 4.Node的底层运行原理、和浏览器的异同

  • 5.Node事件驱动、非阻塞机制的实现原理

六、框架和类库


轮子层出不穷,从原理上理解才是正道

TypeScript

  • 1.理解泛型接口等面向对象的相关概念,TypeScript对面向对象理念的实现

  • 2.理解使用TypeScript的好处,掌握TypeScript基础语法

  • 3.TypeScript的规则检测原理

  • 4.可以在ReactVue等框架中使用TypeScript进行开发

React

  • 1.Reactvue选型和优缺点、核心架构的区别

  • 2.ReactsetState的执行机制,如何有效的管理状态

  • 3.React的事件底层实现机制

  • 4.React的虚拟DOMDiff算法的内部实现

  • 5.ReactFiber工作原理,解决了什么问题

  • 6.React RouterVue Router的底层实现原理、动态加载实现原理

  • 7.可熟练应用React API、生命周期等,可应用HOCrender propsHooks等高阶用法解决问题

  • 8.基于React的特性和原理,可以手动实现一个简单的React

Vue

  • 1.熟练使用VueAPI、生命周期、钩子函数

  • 2.MVVM框架设计理念

  • 3.Vue双向绑定实现原理、Diff算法的内部实现

  • 4.Vue的事件机制

  • 5.从template转换成真实DOM的实现机制

多端开发

  • 1.单页面应用(SPA)的原理和优缺点,掌握一种快速开发SPA的方案

  • 2.理解Viewportemrem的原理和用法,分辨率、pxppidpidp的区别和实际应用

  • 3.移动端页面适配解决方案、不同机型适配方案

  • 4.掌握一种JavaScript移动客户端开发技术,如React Native:可以搭建React Native开发环境,熟练进行开发,可理解React Native的运作原理,不同端适配

  • 5.掌握一种JavaScript``PC客户端开发技术,如Electron:可搭建Electron开发环境,熟练进行开发,可理解Electron的运作原理

  • 6.掌握一种小程序开发框架或原生小程序开发

  • 7.理解多端框架的内部实现原理,至少了解一个多端框架的使用

数据流管理

  • 1.掌握ReactVue传统的跨组件通信方案,对比采用数据流管理框架的异同

  • 2.熟练使用Redux管理数据流,并理解其实现原理,中间件实现原理

  • 3.熟练使用Mobx管理数据流,并理解其实现原理,相比Redux有什么优势

  • 4.熟练使用Vuex管理数据流,并理解其实现原理

  • 5.以上数据流方案的异同和优缺点,不情况下的技术选型

实用库

  • 1.至少掌握一种UI组件框架,如antd design,理解其设计理念、底层实现

  • 2.掌握一种图表绘制框架,如Echart,理解其设计理念、底层实现,可以自己实现图表

  • 3.掌握一种GIS开发框架,如百度地图API

  • 4.掌握一种可视化开发框架,如Three.jsD3

  • 5.工具函数库,如lodashunderscoremoment等,理解使用的工具类或工具函数的具体实现原理

开发和调试

  • 1.熟练使用各浏览器提供的调试工具

  • 2.熟练使用一种代理工具实现请求代理、抓包,如charls

  • 3.可以使用AndroidIOS模拟器进行调试,并掌握一种真机调试方案

  • 4.了解VueReact等框架调试工具的使用

七、前端工程


前端工程化:以工程化方法和工具提高开发生产效率、降低维护难度

项目构建

  • 1.理解npmyarn依赖包管理的原理,两者的区别

  • 2.可以使用npm运行自定义脚本

  • 3.理解BabelESLintwebpack等工具在项目中承担的作用

  • 4.ESLint规则检测原理,常用的ESLint配置

  • 5.Babel的核心原理,可以自己编写一个Babel插件

  • 6.可以配置一种前端代码兼容方案,如Polyfill

  • 7.Webpack的编译原理、构建流程、热更新原理,chunkbundlemodule的区别和应用

  • 8.可熟练配置已有的loadersplugins解决问题,可以自己编写loadersplugins

nginx

  • 1.正向代理与反向代理的特点和实例

  • 2.可手动搭建一个简单的nginx服务器、

  • 3.熟练应用常用的nginx内置变量,掌握常用的匹配规则写法

  • 4.可以用nginx实现请求过滤、配置gzip、负载均衡等,并能解释其内部原理

开发提速

  • 1.熟练掌握一种接口管理、接口mock工具的使用,如yapi

  • 2.掌握一种高效的日志埋点方案,可快速使用日志查询工具定位线上问题

  • 3.理解TDDBDD模式,至少会使用一种前端单元测试框架

版本控制

  • 1.理解Git的核心原理、工作流程、和SVN的区别

  • 2.熟练使用常规的Git命令、git rebasegit stash等进阶命令

  • 3.可以快速解决线上分支回滚线上分支错误合并等复杂问题

持续集成

  • 1.理解CI/CD技术的意义,至少熟练掌握一种CI/CD工具的使用,如Jenkins

  • 2.可以独自完成架构设计、技术选型、环境搭建、全流程开发、部署上线等一套完整的开发流程(包括Web应用、移动客户端应用、PC客户端应用、小程序、H5等等)

八、项目和业务


后端技能

  • 1.了解后端的开发方式,在应用程序中的作用,至少会使用一种后端语言

  • 2.掌握数据最终在数据库中是如何落地存储的,能看懂表结构设计、表之间的关联,至少会使用一种数据库

性能优化

  • 1.了解前端性能衡量指标、性能监控要点,掌握一种前端性能监控方案

  • 2.了解常见的WebApp性能优化方案

  • 3.SEO排名规则、SEO优化方案、前后端分离的SEO

  • 4.SSR实现方案、优缺点、及其性能优化

  • 5.Webpack的性能优化方案

  • 6.Canvas性能优化方案

  • 7.ReactVue等框架使用性能优化方案

前端安全

  • 1.XSS攻击的原理、分类、具体案例,前端如何防御

  • 2.CSRF攻击的原理、具体案例,前端如何防御

  • 3.HTTP劫持、页面劫持的原理、防御措施

业务相关

  • 1.能理解所开发项目的整体业务形态、业务目标、业务架构,可以快速定位线上业务问题

  • 2.能理解所开发项目整体的技术架构、能快读的根据新需求进行开发规划、能快速根据业务报警、线上日志等定位并解决线上技术问题

  • 3.可以将自己的想法或新技术在业务中落地实践,尽量在团队中拥有一定的不可替代性

九、学习提升


vczh大神在知乎问题【如何能以后达到温赵轮三位大神的水平?】下的回答:

这十几年我一共做了三件事:- 1、不以赚钱为目的选择学习的内容;- 2、以自己是否能造出轮子来衡量学习的效果;- 3、坚持每天写自己的代码,前10年每天至少6个小时,不包含学习和工作的时间。

上面几点可能有点难,第一点我就做不到,但是做到下面绩点还是比较容易的。

关于写博客说明下,能给别人讲明白的知识会比自己学习掌握的要深刻许多

  • 1.拥有自己的技术博客,或者在一些博客平台上拥有自己的专栏

  • 2.定期的将知识进行总结,不断完善自己的知识体系

  • 3.尽量将自己的知识转换成真实的产出,不要仅仅停留在书面理解层面,更重要的是实际应用

  • 4.坚持输出自己的代码,不要盲目的扎进公司业

十、技术之外


这部分可能比上面九条加起来重要!

  • 1.了解互联网人员术语:CEOCTOCOOCFOPMQAUIFEDEVDBAOPS

  • 2.了解互联网行业术语:B2BB2CC2CO2O

  • 3.掌握互联网行业沟通、问答、学习的

  • 4.有一定的"PPT"能力

  • 5.有一定的理财意识,至少了解储蓄、货币基金、保险、指数基金、股票等基本的理财知识

  • 6.掌握在繁重的工作和长期的电脑辐射的情况下保持健康的方法,建立正确的养生知识体系

十一、资源推荐


有了知识体系,在阅读一篇技术文章的时候就很容易把它归类,我一直以来就是这样做的。

事实证明,在阅读文章或书籍时,有目的和归类的阅读比"随便看看"后的只是留存率要高很多。

每阅读到一篇好的文章或者书籍,我都会收藏并归类到我的知识体系中。

下面是一些我觉得还不错的文章、博客或者书籍教程等等,分享给大家,资源不多,但都是精品。

学习一门知识,最好先阅读官方文档,把所有的API大概浏览一遍,再继续看大佬们总结的进阶知识,什么东西是搬运过来的,什么是干货,一目了然。

语言基础

  • [???]JavaScript高级程序设计(必看):book.douban.com/subject

  • [???]高性能JavaScript:book.douban.com/subject

  • 现代JavaScript教程:zh.javascript.info/

  • 阮一峰的ECMAScript 6教程:es6.ruanyifeng.com/

  • ECMAScript 6标准:ecma-international.org/

  • HTML meta标签总结与属性使用介绍:segmentfault.com/a/1190

  • CSS编码指导:github.com/chadluo/CSS-

计算机基础

  • 大前端开发者需要了解的基础编译原理和语言知识:fullstack.blog/2017/06/

  • 图解HTTP:book.douban.com/subject

  • [???]JavaScript设计模式与开发实践:book.douban.com/subject

  • 正则表达式30分钟入门教程:link.juejin.im/?

数据结构和算法

  • 数据结构与算法之美:time.geekbang.org/colum

  • 用动画的形式呈现解LeetCode题目的思路:github.com/MisterBooo/L

  • JavaScript数据结构和算法:github.com/ConardLi/awe

  • 30-seconds-of-code(里面有很多js代码非常巧妙,我正在将它翻译成中文):github.com/ConardLi/30-

运行环境

  • 《重学前端》中的浏览器原理章节:time.geekbang.org/colum

  • 图解浏览器的基本工作原理:zhuanlan.zhihu.com/p/47

  • 七天学会NodeJS:github.com/nqdeng/7-day

  • Node.js模块加载与运行原理:efe.baidu.com/blog/node

框架和类库

  • TypeScript Handbook:zhongsp.gitbooks.io/typ

  • React.js小书:huziketang.mangojuice.top

  • React深入系列:juejin.im/post/5cad39b3

  • Webpack React小书:fakefish.github.io/reac

  • Vue.js技术揭秘:github.com/ustbhuangyi/

  • Vuex-在Vue中管理状态:sabe.io/tutorials/getti

  • 你需要Mobx还是Redux?:juejin.im/post/5a7fd72c

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

由于篇幅限制,pdf文档的详解资料太全面,细节内容实在太多啦,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!有需要的程序猿(媛)可以帮忙点赞+点击【学习资料】即可免费领取!

/ustbhuangyi/

  • Vuex-在Vue中管理状态:sabe.io/tutorials/getti

  • 你需要Mobx还是Redux?:juejin.im/post/5a7fd72c

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

[外链图片转存中…(img-ePsE44AG-1713644758104)]

[外链图片转存中…(img-L6tRCnsq-1713644758105)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

[外链图片转存中…(img-7tozbiLF-1713644758105)]

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

[外链图片转存中…(img-gm379vCV-1713644758105)]

最后

由于篇幅限制,pdf文档的详解资料太全面,细节内容实在太多啦,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!有需要的程序猿(媛)可以帮忙点赞+点击【学习资料】即可免费领取!

[外链图片转存中…(img-JXsuLNf1-1713644758105)]

[外链图片转存中…(img-vt2v0tOj-1713644758106)]

  • 12
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值