从月薪3000到月薪30000,web前台应该这么学!【附教程和前台学习路线】

作者 : 开心源码 本文共5911个字,预计阅读时间需要15分钟 发布时间: 2022-05-13 共213人阅读

很多人都想学编程。但是苦于没有具体的步骤和指导。比方想找份前台开发的工作,却不知道应该先学习什么再学习什么,也不知道该选择什么样的工具。

由于经常被人问到相似的问题,全栈开发者Kamran Ahmed索性在github上制订了一份现代前台开发的路线图,并且用一篇文章对前台开发的整个学习过程进行了详细解释。感兴趣的初学者不容错过。

进入正题之前先交代一下我和这张路线图的背景。过去5年我一直在进行全栈开发,目前是tajawal的首席工程师(我得有很多头衔)。

关注趋势并且让其余开发者训练得当不仅是我的爱好也是我的工作职责。在如何跟上形势方面我发现有很多新手(也包括少量有经验的)都感到很困惑。

2017年的时候我有很多朋友都发邮件给我寻求指导,他们想知道做这一行的话应该学些什么。所以为了避免自己老是要碰到这样的麻烦同时也是为了帮助别人,我决定一劳永逸准备这些图表,这样只需有人问我时就把这些图表的链接发给他们。所以这些图表就是这么诞生的。

同时我还在制作后台和DevOps部分的路线图,但是前台已经做好了,你可以看看下面。

好了,下面开始吧——下面就是这份路线图,但是本文的目的是依次解释路线图的每一个步骤。

你首先想要去做的第一件事是学习少量基础,包括学习HTML、CSS的一点基础知识,以及熟习一下JavaScript的语法。

学习HTML基础

HTML给你的网页赋予了结构。它就像是人的骨架那样让你保持站立。首先你需要去学习语法以及它必需提供的一切。你的学习应该聚焦在下面这些东西上:

学习HTML基础,理解如何编写语义HTML

了解如何把网页分成section(段落),以及如何正确组织DOM(文档对象模型)

任务——一旦你学习了HTML基础,至少要制作5个HTML网页。我建议你随意找一个

网站,比方看看Github的档案页或者者Twitter的登录页。而后把焦点放在恰当地组织内容上。出来的东西可能会很难看,但是暂时别担心,把你的关注点放在恰当的结构上。

学点CSS

现在我们已经学会了如何给网页准备好骨架,接下来就是在此基础上增加少量皮肤让它好看一点了。CSS——级联样式表就是用来美化你的HTML页面的。

首先要做的是学习语法,熟习常见的CSS属性。

理解盒模型(box model),掌握如何利用Grid和Flexbox准备布局

一旦学习完上面的,再学习以下通过媒体查询把网站做成响应式的。

任务——一旦你掌握了基础,接下来就应该设计上一步制作的HTML网页。比如说假如你给Github档案编写了HTML页面的话,现在是时候应用CSS来让它的样子看起来像实际的Github资料页面一样了。前面的那5个页面都要拿来试一下。

学习JavaScript基础

JavaScript能让你的HTML页面互动性更强。比如说你在网站上看过的所有那些幻灯片、弹出窗口以及广播通知,以及在没有重载页面的情况下重载页面的特定部分,这些都是用JavaScript做的。在这一步中,你将会学习JavaScript的基础来为后面的旅程做好准备——

学习这门语言的语法和基本机构。

学习如何用JavaScript来操纵DOM,比如说如何从页面移除少量元素,如何添加少量元素,添加和移除类,通过JavaScript应用CSS样式等。

完成之后再学习和了解诸如范围、闭包、变量提升以及事件冒泡这样的主题。

学习如何用XHR或者者Ajax生成HTTP调用。Ajax可以让你在不需要重载网页的情况下执行特定动作。

学完之后接下来就要理解ES6+的所有新特性。ES6只是JavaScript的一个版本,里面给这门语言引入了大量有趣的升级,比方类、定义变量的多种方式,给数组添加了新的方法,字符串连接等。你们在网上找到的大部分文章都会用Babel来解析ES6,这其实是个转译器,可以将这门新的JavaScript转换为旧的JavaScript,由于有少量旧版的浏览器不支持新版的JS。不过现在先不用担心Babel,只要要理解相关概念,而后用到任何一种支持ES6的最新版浏览器上来练习一下就行。我们后面还会再继续讲ES6的。

现在你应该已经感觉到东西像是那么一回事了。假如你按照上面的步骤做下来的话应该鼓励一下。这些是你刚刚学到的少量最重要的东西。

我应该学jQuery吗?

曾经有一段时间每个人都对jQuery疯狂,也有充分的理由;这是一个强大的库,在JavaScript基础上提供了一个封装,让你可以用兼容浏览器的方式执行任何东西。不过那些日子已经一去不复返,现在新项目用它已经不是很多了,但是依然还有人在用。你不是肯定要学它,但是这玩意儿确实很容易,假如你想看看的话还是有好处的。

练习时间

我已经说过很屡次但是还是要再说一次,不练习的话你学不到任何东西。你可能随时都会感觉自己已经了解了但是假如不练习的话很快就会忘掉。在按照这份路线图去学习的时候,要确保尽可能多地去上手实践。

继续做些响应式网站,用JavaScript添加交互性。你可以增加任何感兴趣的现有的网页上去,但记住要利用上目前学到的一切

一旦你制作出了少量网站,接下来就是开始做真正的东西了。你可以到github上面找少量项目打开某些开源项目的pull请求。以下就是少量可以去尝试的pull请求:

加强UI,把任何演示页做成响应式或者者改进设计

看看有什么开放的issue是你能够处理的

重构任何你认为自己可以改进的代码

就像这个repo一样,告诉他们你正在学习让他们就你的PR以及可以如何加以改进提供反馈。

虽然我愿意推荐这个Github库,但是这需要理解一点git的知识,所以这是可选的。你不必做这个但假如你做了的话,你会发现真的很有用——只需你开口你会惊讶地发现居然有那么多人愿意帮助你。那你也可以找到很多有关git的免费资源,比方试试这个。

鼓励自己一下

现在你已经学习了必要的基础了。假如一切都学得不错的话,你即可以去找份自由职业工作或者者也许可以去试试能不能找份全职了。然而,假如你想有一份更好的职业的话,现在还不能中止脚步,由于还有很长一段路要走。

包管理器

在此之前,假如你要用到少量外部库比方插件或者者任何外部的桌面小部件的话,你得手工下载JavaScript和CSS文件并且将它们放到项目里面,而后那些库或者者插件发布新版本的时候,你又得下载升级的文件再放到你的项目里面,这是极其麻烦的事情。包管理器可以干掉这种麻烦。它们帮助你把外部库和插件放到你的项目里面,这样你就不用关心手工复制库或者者费事地在它们发布新版时升级文件的事情了。现在有yarn和npm了。这两个几乎是一样的,都只是实现,你可以任选一个,一旦学会了使用其中一个,另一个自然也不成问题。

现在学以致用吧

在对包管理器有了基本理解之后,你即可以去安装少量外部库到你前面制作的少量网页上了,比方安装少量提醒插件,当客户点击某个按钮时显示提醒信息,或者者创立一个登录表单用少量表单验证库进行表单验证,或者者试试不同的选项看看如何安装不同的版本。

记得要看看语义版本控制

CSS预解决器

预解决器以CSS默认不支持的功能丰富了后者。可选项有很多,包括Sass、Less、Stylus等等。要我选的话,我会选择Sass。

然而,PostCSS最近的发展势头也不错,这属于一个锦上添花的东西,有点相似于CSS的“Babel”。你可以拿来独立使用或者者在Sass的基础上叠加。目前我建议你先学Sass,等后面有时间了再看看PostCSS。

CSS框架

你已经不再需要学习CSS框架了,然而假如你想学一个的话。我会推荐在Bootstrap、Materialize和Bulma里面选。但假如你要考虑它们的市场需求的话,我会选择Bootstrap。

CSS组织

随着你的应用不断膨胀,CSS也开始变得混乱难以维系。有多种手段可以对你的CSS进行组织,让它更好地应对伸缩性,比方OOCSS、SMACSS、SUITCSS、Atomic以及BEM。你应该理解它们之间的不同,但是我更偏好BEM。

构建工具

工具可以帮助你进行JavaScript应用的构建/打包以及开发。这一类包括了linter(代码检查)、task runner(自动构建)以及bundler(打包工具)。

对于自动构建,这个原本是是很多选项的,包括npm脚本、gulp、grun等等。不过这一次,既然webpack能够解决gulp能做的大部分东西,所以只有自动构建中的npm脚本可以用来对webpack能做的任务进行自动化。你不需要学习Gulp,然而到后面假如你有点时间的话,可以去看看它是否对你的应用有所帮助。

至于linter,再次地也有很多选项,其中包括ESLint、JSLint、JSHint以及JSCS等。但是目前主要是ESLint用得多。

对于模块打包工具,不同的选项包括Parcel、Webpack、Rollup、Browserify等。假如你必需选一个,目前你可以闭着眼睛选Webpack就是。Rollup也很常用但是主要建议用到库上面,至于app,还是以webpack为主。所以现在你就先学习一下webpack吧,后面假如想的话再理解一下Rollup。

练习时间 —— 做点什么

恭喜你!你现在可以称自己为75%的现代JavaScript开发者了。现在继续用你学到的东西做点什么出来。也许可以做个库将来用到Sass和JavaScript上。而后用Webpack将Sass转换成CSS,用babel转换成ES6代码。一旦你做完了再把它发布到Github和npm上。

选一个框架

在旧的路线图中,这个部分往往是紧挨着基础部分的,但是这次我改到放在Sass、构建工具和包管理器后面了,由于在框架中你全都会用上那些东西,假如不具有相应知识的话会吓到你的。

框架也有好些选项。不过目前比较常用的是React、Vue和Angular。最近对React.js的需求越来越旺盛。然而,前面列的这几个你随意选一个都不会错。我个人会选React或者者Angular。不过特别说明一下,作为初学者你也许会发现相对而言Angular会容易点,也许是由于它支持几乎一切立就可用的东西,比方支持推迟加载的强大路由器,支持阻拦器的HTTP用户端,依赖注入,组件CSS封装等而不需要关心选择外部库的问题。不过React在社区方面无疑更有优势,而且Facebook一直都在努力改进它。你需要确保的是不要由于什么东西火就选择什么,要去google一下,比照一下,看看哪一个最适合你。

这两个的比较以及我的个人体会我要留到下一篇文章再谈了,不过既然这篇文章是谈学习的,我就来讲讲如何找到Angular和React的学习曲线。

下图中的学习曲线考虑了你已经具有TypeScript的知识,而且也懂了少量Rx.JS的基础。至于这种假设的起因我会在将来的文章中解释,不过主要是由于Angular提供的其中的少量即时可用的标准和关键功能。但这并不意味着React就是坏的,它们各自都有自己的地位,我以后会进一步细谈。

你可以看看各自的学习曲线,看看哪个更适合你。

一旦你选择了自己的框架,当然还有其余少量东西需要你学的。比如说假如你决定学React的话,你可能还得学Redux或者者Mobx去理解状态管理,具体选学什么要取决于你要做的应用的规模。Mobx适合中小规模应用,Redux更适合大规模应用。甚至你可能都不需要学,靠React的原生状态管理就行了,假如你的app允许的话。

假如你选择Angular,你就得用TypeScript(没有它你也能开发出Angular应用,但是我们还是推荐你使用)和Rx.js,这些除了Angular应用以外在其余地方也能用得上。这都是非常强大的库,也适合于函数编程开发。

假如你选了Vue.js的话,也许还得学习Vuex,这东西有点相似于Redux但是是给Vue用的。

需要注意的是,Redux、Mobx以及Rx.js都不是跟这些框架绑死到一起的,你也可以用到各种JavaScript应用里面。此外,假如你选择了Angular的话,确保你用的是Angular 2+而不是Angular 1+。

练习时间

现在你已经知道了开发现代JavaScript应用所需的一切。现在就用你选择的框架做点东西出来吧。你会在库中的idea目录找到少量点子;任选一个而后开始吧!

做完之后,再去看看如何衡量和改进性能。比如说可以看看Interactivity Time、Page Speed Index以及Lighthouse Score等。

渐进式Web应用

一旦完成了上述所有步骤,再来学习一下service worker以及如何制作渐进式web应用。

测试你的应用

应用测试有很多工具,各自的用途也不一样。我本人经常是组合使用Jest、Mocha、 Karma及Enzyme。然而,在开始选择工具之前,最好是首先了解有哪些不同的测试类型,看看所有的选项情况,而后从中再选择最适合您需求的一个。

这里有一份很好的概括,你可以去看看。

静态类型检查器

静态类型检查器帮助给JavaScript添加类型检查。你不需要学习这些,不过这些东西可以赋予你超能力,而且学习起来也很快,几个钟头就行了。这方面主要有TypeScript 和 Flow。我喜欢TypeScript ,不过你可以两个都看看,再选你喜欢的。

服务器渲染

目前为止,你所学到的技能应该足够你找到一个“前台工程”的位置了。但且慢,你还可以更上一层楼。

你还可以在选定的任何框架内再学学服务器端渲染的知识。有不同的选项可选,这要取决于你用什么样的框架。比如说假如你决定用React,最值得关注的选项是Next.js 和 After.js。假如是Angular,你可以选Universal。对于Vue.js,我们有 Nuxt.js。

这份路线图可能还会有遗漏的地方,但是足以应付任何“前台工程”角色之所需。还要记住的是,关键是尽可能多地练习。一开始你可能会觉得很吓人,总感觉自己没有掌握,但这是正常的,慢慢你就会觉得自己变得越来越好。还有,陷入困境时别忘了寻求帮助,你会惊喜地发现有多少人愿意帮助你的,或者者至少我愿意。

我目前是在职前台开发,假如你现在也想学习前台开发技术,在入门学习前台的过程当中有遇见任何关于学习方法,学习路线,学习效率等方面的问题,你都可以申请加入我的前台学习交流裙:前面:603 中间:985 最后:993。里面聚集了少量正在自学前台的初学者裙文件里面也有我做前台技术这段时间整理的少量前台学习手册,前台面试题,前台开发工具,PDF文档书籍教程,需要的话都可以自行来获取下载。

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » 从月薪3000到月薪30000,web前台应该这么学!【附教程和前台学习路线】

发表回复