同时 , 我们还需要对DOM有一些基础的了解 , 才能做一些基本的操作 , 如修改颜色等等 。在这种情况下,最简单的方案就是使用jQuery这样的工具 。不过,如果可以自己操作DOM是再好不过的了 。
中级篇
中级篇就更有意思了 , 现在我们就需要对页面进行更复杂的操作 。Ajax和JSON这两个技能是必须的 , 当我们要动态的改变页面的元素时 , 我们就需要从远程获取最新的数据结果 。并且我们也需要提交表单到服务器,RESTful就是必须要学会的技能 。未来我们还需要Fetch API,ReactiveX这些技能 。
除此我们还需要掌握好HTML的语义化,像DIV / CSS这也会必须会的技能,我们应该还会使用模板引擎和SCSS / SASS 。而这个层面来说,我们开始使用Node.js来完成前端的构建等等的一系列动作,这时候必须学会使用命令行这类工具 。并且,在这时候我们已经开始构建单页面应用了 。
高级篇
JavaScript是一门易上手的语言,也充满了相当多的糟粕的用法 。几年前人们使用CoffeeScript编成成JavaScript来编写更好的前端代码,现在人们有了ES6、TypeScript和WebPack来做这些事 。尽管现在浏览器支持不完善,但是他们是未来 。同样的还有某些CSS3的特性,其对于某些浏览器来说也是不支持的 。而这些都是基于语言本来说的,要写好代码,我们还需要掌握面向对象编程、函数式编程、MVC / MVVM / MV*这些概念 。作为一合格的工程师,我们还需要把握好安全性(如跨域) , 做好 授权(如HTTP Basic、JWT等等) 。
工程化
这个标题好像是放错了,这部分的内容主要都是自动构建的内容 。首先,我们需要有基本的构建工具 , 无论你是使用gulp、grunt,还是只使用npm,这都不重要 。重要的是,你可以自动化的完成构建的工具,编译、静态代码分析(JSLint、CSS Lint、TSLint)、对代码质量进行分析(如Code Climate,可以帮你检测出代码中的Bad Smell)、运行代码中的测试,并生成测试覆盖率的报告等等 。这一切都需要你有一个自动构建的工作流 。
兼容性
虽然我们离兼容IE6的时代已越来越远了,但是我们仍然有相当多的兼容性工作要做 。基本的兼容性测试就是跨浏览器的测试,即Chrome,IE,Firefox,Safari等等 。除此还有在不同的操作系统上对同一浏览器的测试,某些情况下可能表现不一致 。如不同操作系统的字体大小,可能会导致一些细微的问题 。
而随着移动设备的流行,我们还需要考虑下不同Android版本下的浏览器内核的表现不致 , 有时候还要一下不成器的Windows Phone 。除此,还有同一个浏览器的不同版本问题,常见于IE 。
前端特定
除了正常的编码之外,前端还有一些比较有意思的东西,如CSS3和JavaScript动画 。使用Web字体,可惜这个不太适合汉字使用 。还有Icon字体,毕竟这种字体是矢量的 。不过Icon字体还有一些问题,如浏览器对其的抗锯齿优化,还有一个痛是你得准备四种不同类型的字体文件 。因此,产生了一种东西SVG Sprite,在以前这就是CSS Sprite,只是CSS Sprite不能缩放 。最后,我们还需要掌握一些基本的图形和图表框架的使用 。
软件工程
这一点上和大部分语言的项目一样,我们需要使用版本管理软件,如git、svn,又或者是一些内部的工具 。总之你肯定要有一个,而不是zip这种文件 。然后,你还需要一些依赖管理工具,对于那些使用Webpack、Browserify来将代码编写成前端代码的项目来说,npm还是挺好用的 。不过就个人来说,对于传统的项目来说我总觉得bower有些难用 。我们还需要模块化我们的源码文件 , 才能使其他人更容易开始项目 。
经验总结扩展阅读
- 口罩的正确戴法,口罩的正确戴法是什么?
- 420105是武汉市哪个区,武汉洪山区身份证号前六位是什么
- 黄体酮为什么会低,怀孕黄体酮低是什么原因造成的?
- 脱产是什么意思,脱产是什么意思
- 生抽是什么,生抽是什么东西
- 破壁机和豆浆机的区别,破壁机和豆浆机的区别是什么?
- 介绍一种动物的住宅,动物对自己的住宅都很看重你觉得哪种动物修建自己的住宅很有意思给大家介绍一下?
- 马克华菲手表怎么拆后盖,马克华菲手表下面的圈里面是什么
- 莫使金樽空对月下一句是什么,今朝有酒今朝醉,莫使金尊空对月。
- 2023立春的含义是什么意思 2023立春有何含义