目前前端市场情况:初级前端供大于求,在培训机构和互联网公司的共同推动下,市场上的的初级前端越来越多。但是高级前端供小于求,本质上因为互联网公司的发展速度高于市场上的前端工程师的平均成长速度。所以,虽然会前端的人现在多了,但是从目前企业招人现状来看,企业招人依然困难。比如,在阿里巴巴供应链平台,企业为了构建一套适用于阿里所有零售场景的供应链解决方案,在系统架构、用户体验和研发效率的平衡等维度做了大量封装、抽象。这是企业的高速发展的必然结果,所以这对前端程序员的要求越来越高,然而市场上能够满足这样场景的同学,少而又少。
前端开发上手快,找到好的方法后入门很轻松,而且前端开发容易得到反馈,因为页面效果是可见的,所以我推荐学习一点内容后快速实战,在实战中找到成就感,发现问题,然后再带着问题回去系统学习,如此往复,然后就会越来越熟练。
首先是编程工具选择
在开始正式学习前端之前,学会使用基本的编程工具会让你的前端学习事半功倍,首先我们是要选择一个好的编辑器和一款好的浏览器,现在有很多的编辑器和浏览器给我们选择,但是无论是刚入门还是有一定经验的前端学习人员,我都推荐VSCode+Chrome这一个组合,百度直接搜就有了,如果在使用过程中有遇到问题可以留言咨询!安装好基本的编程工具以后我们就可以愉快的进行开发啦~
一、基础学习
1、html + css
这部分建议在网上找一些视频教程进行学习,视频教程的好处是有老师讲解,能够更加有利于刚入门的小伙伴快速进入前端行业。在看视频的同时可以在 w3school 在线教程上进行学习,边学边练, w3school 在线教程上每章后还有小测试。建议看明白后自己在编辑器上敲一敲,然后在书上再看看,加深记忆,这对以后的前端学习会打下很深的基础。
2、javascript
javascript是前段开发人员必须要掌握的一门编程语言,前端要学的内容实在很多,如果没有其他编程语言的基础的话,学起来可能要费些力,还是建议先在 w3school上学习,多敲敲代码加强记忆,可以适当做一些笔记,加一些前端开发社区和大佬们聊聊。
当然,书是必不可少的,这是我给大家整理的几本重要的从前端小白到前端大神必备的五本书,希望大家手头都要有,可能很大概率这些书会陪伴大家走很长时间的学习生涯。
有了以上基础,就可以进行一般的静态网页,对于大学生的课程设计一般没什么问题,不过对于企业要求的复杂的页面还有一些距离,需要进一步学习。
二、进阶学习
1. css进阶(css3和基本的css库)
CSS 在刚开始学习的时候看起来非常简单。毕竟,它仅仅就是些样式而已,但是,随着你的不断了解。很快,你会发现 CSS 没你想象的那么简单,它复杂且有深度。学完css基础知识以后我们还需要学一些css库,比如boostrap、elementui等等,这会极大降低我们的工作量,同时也能够增强大家的学习乐趣~
2. html进阶(html5)
我们需要了解html都提供了哪些api,然后项目中用起来。这部分没有什么难理解的,关键在于能用html5解决业务问题,以及不支持html5的浏览器的降级方案。这部分体现了前端的一个思想:面向未来编程,尽早将新技术引入业务中来,而不是过分考虑兼容性问题,进而导致面向过去编程。
3. javascript进阶(js高级和js框架)
首先是javascript 语言范式 。javascript不完全是一个面向对象的语言,它的很多设计理念都有函数编程语言的影子,甚至说如果你不用面向对象,完全可以把它理解成一门函数式编程语言。javascript的很多语言特性,都是因为他具有函数式语言的特点才存在的。这部分推荐先学习面向对象的基本理论,对封装,继承,多态等概念要理解,
然后是框架的学习。目前js主流的框架有 react、vue、angular 等es6入门教程,他们不直接操作dom。这类框架建议js基础打扎实后再学习。复杂框架是用来解决复杂问题的。对于电商无线端导购页面来说原生JS足以。对于类似商家管理系统这类交互复杂,开发量大的系统,才适合用这类框架。对于这些框架核心在于理解理念,不要只停留在会用的层面。
还要学es5, es6。现在开发js大部分基于es5的,ie8以下通过es5-shim。但利用一些工具,现在已经可以直接写es6代码了,尤其在reactjs,nodejs类型的项目中。对于从es5,es6每个阶段js发生了哪些变化都需要系统学习,学习顺序建议是 JavaScript基础 -> es5 -> es6,越靠前的越重要。
4.数据结构和算法
开篇就提到了目前市场缺的是高级前端,初级到高级的门槛不在未来,而是在过去的大学基础课。
前端为什么要学数据结构和算法呢?因为这些都是稍微复杂一点的场景解决问题的必备武器。比如,把一个列表形式的地址数据,以树形渲染到页面,或者反过来;又比如,把一个多级嵌套的数据对象,转化成扁平的map结构再提交到服务器。更关键的,数据结构和算法,是计算机的思维方式,尤其是分治递归的思想,影响到代码实现、模块设计、乃至到系统设计,所以这是现在前端人员必须要掌握的知识,也是很多大公司目前招人必问的问题。
三、高级学习(关注代码质量和用户体验)
高级前端追求的是代码的高内聚、低耦合,高内聚低耦合是判断设计好坏的标准,主要是面向对象的设计,主要看类的内聚性是否高,耦合度是否低,目的是使得模块的可重用性、移植性大大增强。如果说数据结构和算法是从初级到高级的第一道门槛,能否写出高内聚、低耦合的代码,则是第二道门槛,这就需要慢慢去摸索,去找资料学习,当然进入公司以后还可以慢慢学习。
还有前端工程师追求极致的用户体验和工程效率,对于前端页面极致的用户体验围绕这三方面:加载体验、渲染体验、操作体验。千万不可以只知道优化加载体验,5G时代即将来临,网络速度回得到进一步提升,但CPU处理速度,貌似还没看到突破性进展,未来的用户体验问题,会更加聚焦到渲染体验和操作体验。
同时,前端项目同样面临软件生命周期的各个环节,首先是代码管理,你必须学会使用git。其次是代码的构建,如今前端代码构建已经不是简单的压缩一下了es6入门教程,需要进行依赖管理、模块合并、各种编译,必须要学会使用webpack、rollup等前端构建工具,以及前端模块管理的方式,amd,cmd,es6 module 等等。
前端这条路美好而又艰辛,需要我们不断地学习,去更新自己的知识,停留只会让我们离别人越来越远。
只要坚持,相信大家都可以从小白进阶到高级前端工程师!
(大家有任何问题欢迎来评论区留言,“前端猿”也会不断为大家提供最新的前端信息~)
———END———
限 时 特 惠:本站每日持续更新海量各大内部创业教程,一年会员只需128元,全站资源免费下载点击查看详情
站 长 微 信:jiumai99